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];
    }
}
相关推荐
WBluuue1 小时前
数据结构与算法:摩尔投票算法
c++·算法·leetcode
小羊学伽瓦1 小时前
【Java数据结构】——常见力扣题综合
java·数据结构·leetcode·1024程序员节
文火冰糖的硅基工坊2 小时前
[人工智能-大模型-66]:模型层技术 - 两种编程范式:数学函数式编程与逻辑推理式编程,构建起截然不同的智能系统。
人工智能·神经网络·算法·1024程序员节
im_AMBER2 小时前
Leetcode 34
算法·leetcode
im_AMBER2 小时前
Leetcode 31
学习·算法·leetcode
LucianaiB3 小时前
仓颉语言核心技术解析:如何开发高性能服务端应用
职场和发展·高性能·语言·仓颉
吃着火锅x唱着歌3 小时前
LeetCode 74.搜索二维矩阵
算法·leetcode·矩阵
mit6.8243 小时前
hash|快速幂|栈
算法
OG one.Z3 小时前
06_决策树
算法·决策树·机器学习