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];
    }
};
相关推荐
迷途之人不知返1 天前
stack和queue的学习与模拟实现
c++
汉克老师1 天前
GESP2025年3月认证C++五级( 第二部分判断题(1-10))
c++·算法·分治算法·线性筛法·gesp5级·gesp五级
橙子也要努力变强1 天前
volatile与信号
linux·服务器·c++
洛水水1 天前
【力扣100题】17.K 个一组翻转链表
算法·leetcode·链表
洛水水1 天前
【力扣100题】16.两两交换链表中的节点
算法·leetcode·链表
Shadow(⊙o⊙)1 天前
智能指针、循环引用、锁、删除器
开发语言·c++·后端·visual studio
水云桐程序员1 天前
C++官方文档获取平台
c++·学习方法
leoufung1 天前
LeetCode 30:Substring with Concatenation of All Words 题解(含 C 语言 uthash 实现)
c语言·leetcode·c#
Sylvia-girl1 天前
C++模板【上】
开发语言·c++
王老师青少年编程1 天前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:荷马史诗
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·荷马史诗