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];
    }
};
相关推荐
不染尘.9 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
似水এ᭄往昔9 小时前
【C++】--stack和queue
开发语言·c++
仰望—星空10 小时前
MiniEngine学习笔记 : CommandListManager
c++·windows·笔记·学习·cg·direct3d
怕什么真理无穷11 小时前
C++面试4-线程同步
java·c++·面试
fpcc11 小时前
c++23中的print和println
c++·c++23
玉树临风江流儿12 小时前
C++左值、右值、move移动函数
开发语言·c++
许长安13 小时前
c/c++ static关键字详解
c语言·c++·经验分享·笔记
Murphy_lx14 小时前
C++ thread类
开发语言·c++
月夜的风吹雨14 小时前
【C++ STL 深度剖析】:vector 底层模拟实现与核心陷阱解析
c++·vector·类和对象·visual studio
彩妙不是菜喵14 小时前
C++ 中 nullptr 的使用与实践:从陷阱到最佳实践
开发语言·jvm·c++