C++ | Leetcode C++题解之第416题分割等和子集

题目:

题解:

cpp 复制代码
class Solution {
public:
    bool canPartition(vector<int>& nums) {
        int n = nums.size();
        if (n < 2) {
            return false;
        }
        int sum = 0, maxNum = 0;
        for (auto& num : nums) {
            sum += num;
            maxNum = max(maxNum, num);
        }
        if (sum & 1) {
            return false;
        }
        int target = sum / 2;
        if (maxNum > target) {
            return false;
        }
        vector<int> dp(target + 1, 0);
        dp[0] = true;
        for (int i = 0; i < n; i++) {
            int num = nums[i];
            for (int j = target; j >= num; --j) {
                dp[j] |= dp[j - num];
            }
        }
        return dp[target];
    }
};
相关推荐
普通网友17 分钟前
内存对齐与缓存友好设计
开发语言·c++·算法
小白程序员成长日记18 分钟前
2025.11.18 力扣每日一题
算法·leetcode·职场和发展
普通网友40 分钟前
C++编译期数据结构
开发语言·c++·算法
代码程序猿RIP1 小时前
【C++开发面经】全过程面试问题详解
java·c++·面试
普通网友1 小时前
嵌入式C++安全编码
开发语言·c++·算法
云知谷1 小时前
【软件测试】《集成测试全攻略:Mock/Stub 原理 + Postman/JUnit/TestNG 实战》
c语言·开发语言·c++·软件工程·团队开发
普通网友2 小时前
分布式锁服务实现
开发语言·c++·算法
普通网友2 小时前
移动语义在容器中的应用
开发语言·c++·算法
teacherlg2 小时前
Source Insight 乱码问题解决
c++·乱码·编码·sourceinsight
未若君雅裁2 小时前
LeetCode 18 - 四数之和 详解笔记
java·数据结构·笔记·算法·leetcode