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];
    }
};
相关推荐
cpp_25011 天前
P1024 [NOIP 2001 提高组] 一元三次方程求解
数据结构·c++·算法·题解·二分答案·洛谷·csp
田梓燊1 天前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
张健11564096481 天前
使用信号量限制并发数量
开发语言·c++
jc06201 天前
6.1云原生之Docker
c++·docker·云原生
叶子野格2 天前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio
Fuyo_11192 天前
C++ 内存管理
c++·笔记
澈2072 天前
C++面向对象:类与对象核心解析
c++·算法
6Hzlia2 天前
【Hot 100 刷题计划】 LeetCode 141. 环形链表 | C++ 哈希表直觉解法
c++·leetcode·链表
handler012 天前
Linux 进程探索:从 PCB 管理到 fork() 的写时拷贝
linux·c语言·c++·笔记·学习
众少成多积小致巨2 天前
GNU Make 核心指南
android·c++