LeetCode hot100-89

https://leetcode.cn/problems/partition-equal-subset-sum/description/?envType=study-plan-v2\&envId=top-100-liked

java 复制代码
416. 分割等和子集
已解答
中等
相关标签
相关企业
给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。

问题分析:

目标是将数组分成两个子集,并且这两个子集的和相等。假设数组 nums 的总和为 S。

如果 S 是奇数,显然无法将数组分割成两个和相等的子集,因为两个相等的子集的和必然是偶数。

如果 S 是偶数,目标是找到一个子集,使得其和为 S / 2。也就是说,问题转化为 判断是否存在一个子集,其和为 S / 2。

动态规划解法:

定义 dp[i] 为是否存在一个子集,其和为 i。

初始化 dp[0] = true,表示和为 0 的子集是存在的(即空子集)。

对每个数 num,从后往前更新 dp 数组:如果 dp[j - num] 为 true,则 dp[j] 也可以为 true,表示可以选择该 num 来组成和为 j 的子集。

第二层循环从target到num自己才能保证dp被更新

java 复制代码
类似于
处理 num = 1:
我们更新 dp[j] 从 j = 11 到 j = 1:
dp[11] = dp[11] || dp[11 - 1] = false || false = false
dp[10] = dp[10] || dp[10 - 1] = false || false = false
dp[9] = dp[9] || dp[9 - 1] = false || false = false
dp[8] = dp[8] || dp[8 - 1] = false || false = false
dp[7] = dp[7] || dp[7 - 1] = false || false = false
dp[6] = dp[6] || dp[6 - 1] = false || false = false
dp[5] = dp[5] || dp[5 - 1] = false || false = false
dp[4] = dp[4] || dp[4 - 1] = false || false = false
dp[3] = dp[3] || dp[3 - 1] = false || false = false
dp[2] = dp[2] || dp[2 - 1] = false || false = false
dp[1] = dp[1] || dp[1 - 1] = false || true = true → dp[1] = true
java 复制代码
class Solution {
    public boolean canPartition(int[] nums) {
        int sum=0;
        for(int i=0;i<nums.length;i++){
            sum += nums[i];
        }
        if(sum%2!=0){
            return false;
        }
        sum=sum/2;
        boolean[] dp = new boolean[sum+1];
        dp[0]=true;
        for(int num : nums){
            for(int i=sum;i>=num;i--){
                dp[i]=dp[i]||dp[i-num];
            }
        }
        return dp[sum];
    }
}
相关推荐
CoovallyAIHub8 分钟前
英伟达ViPE重磅发布!解决3D感知难题,SLAM+深度学习完美融合(附带数据集下载地址)
深度学习·算法·计算机视觉
聚客AI17 小时前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v20 小时前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工1 天前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农1 天前
【React用到的一些算法】游标和栈
算法·react.js
博笙困了1 天前
AcWing学习——双指针算法
c++·算法
moonlifesudo1 天前
322:零钱兑换(三种方法)
算法
NAGNIP2 天前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队2 天前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法
Fanxt_Ja2 天前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表