动态规划 | part03

416. 分割等和子集 - 力扣(LeetCode)

给定一个只包含正整数的非空数组。是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。

注意: 每个数组中的元素不会超过 100 数组的大小不会超过 200

示例 1:

  • 输入: 1, 5, 11, 5
  • 输出: true
  • 解释: 数组可以分割成 1, 5, 511.

示例 2:

  • 输入: 1, 2, 3, 5
  • 输出: false
  • 解释: 数组不能分割成两个元素和相等的子集.

提示:

  • 1 <= nums.length <= 200

  • 1 <= numsi <= 100

    public boolean canPartition(int[] nums) {
    // 1. 空数组检查
    if (nums.length == 0) {
    return false;
    }

    复制代码
      // 2. 计算总和
      int sum = 0;
      for (int i = 0; i < nums.length; i++) {
          sum += nums[i];
      }
      
      // 3. 奇数判断:总和为奇数,无法平分
      if (sum % 2 != 0) {
          return false;
      }
      
      // 4. 目标:背包容量 = 总和的一半
      int target = sum / 2;
      
      // 5. 定义DP数组
      // dp[j] 表示:背包容量为 j 时,能装入的最大物品价值(这里价值=重量=nums[i])
      int[] dp = new int[target + 1];  // 默认初始化为0
      
      // 6. 遍历每个物品(数字)
      for (int i = 0; i < nums.length; i++) {
          
          // 7. 倒序遍历背包容量(关键!必须倒序,防止重复放入同一物品)
          for (int j = target; j >= nums[i]; j--) {
              
              // 8. 状态转移:不放 vs 放,取最大值
              // 不放:dp[j](保持原值)
              // 放:dp[j - nums[i]] + nums[i](腾出空间后的最大价值 + 当前物品价值)
              dp[j] = Math.max(dp[j], dp[j - nums[i]] + nums[i]);
          }
      }
      
      // 9. 判断:背包容量为target时,能否正好装满?
      return dp[target] == target;

    }

解题:

我们目标就是找到sum/ 2是否可以取到,我们的dp数组就代表当前的容量所能装的最大价值。递推公式是dp[j] = Math.max(dp[j], dp[j - nums[i]] + nums[i]),就是考虑放与不放的区别,前者是不放,后者是放入。最后dp[target] == target可以判断此容量的背包的最大价值是否是target,如果是则说明正好被放满了,返回true。

相关推荐
梦梦代码精2 小时前
为什么这个开源的AI平台会火?有点东西。。。
人工智能·算法·机器学习·docker·开源
随意起个昵称2 小时前
线性dp-综合刷题1(Not Alone)
算法·动态规划
-森屿安年-3 小时前
1137. 第 N 个泰波那契数
c++·动态规划
如何原谅奋力过但无声3 小时前
【灵神高频面试题合集09-13】二叉树、二叉搜索树
数据结构·算法·leetcode
皆圥忈3 小时前
磁盘物理结构与文件系统基础讲解
linux·算法
数据仓库搬砖人3 小时前
用 LangGraph 从零搭一个客服 Agent:多轮对话 + 工具调用全流程
算法
GuWenyue4 小时前
告别JS类型坑!Ts为什么在ai时代逐渐成为"第一"语言
前端·算法·typescript
子琦啊4 小时前
哈希与前缀和
算法·哈希算法
Deep-w4 小时前
【MATLAB】基于离散 LQR 的车辆横向轨迹跟踪控制方法研究
开发语言·算法·matlab
Peter·Pan爱编程4 小时前
23. 算法库:用算法代替手写循环
c++·人工智能·算法