Day43 动态规划 part05

Day43 动态规划 part05

1049.最后一块石头的重量II

我的思路:
提示说和划分两个和相等的子集差不多,猛然想到,这道题不就是划分子集,用sum - 和最大*2
代码就是划分和相同的子集的变形

解答:

class Solution {
    public int lastStoneWeightII(int[] stones) {
        int sum = Arrays.stream(stones).sum();
        int target = sum / 2;
        int[] dp = new int[target + 1];
        for(int i = 0; i < stones.length; i++) {
            for(int j = dp.length - 1; j >= stones[i]; j--) {
                dp[j] = Math.max(dp[j], dp[j - stones[i]] + stones[i]);
            }
        }
        return sum - dp[target] * 2;
    }
}

494.目标和

我的思路:
经历了这些个题之后,我发现我要的都是dp[target],要么取值,要么计算,要么判断
这个target决定了背包dp的容量–dp[target + 1]
这道题又出现了dp[j] = dp[j - nums[i]] + xxx

上面其实可以总结为,一维背包问题,其中 dp[j] = dp[i] + dp[j - nums[i]]就是状态转移方程

chatGPT老大哥说
G哥太牛了

解答:

class Solution {
    public int findTargetSumWays(int[] nums, int target) {
        int sum = Arrays.stream(nums).sum();
        if(Math.abs(target) > sum) {
            return 0;
        }
        if((sum + target) % 2 == 1) {
            return 0;
        }
        int mytarget = (sum + target) / 2;
        int[] dp = new int[mytarget + 1];
        dp[0] = 1;
        for(int i = 0; i < nums.length; i++) {
            for(int j = dp.length - 1; j >= nums[i]; j--) {
                dp[j] += dp[j - nums[i]];
            }
        }
        return dp[mytarget];
    }
}

474.一和零

我的思路:
有1和0,是个二维背包问题
这个状态转移方程是dp[i][j] = Math.max(dp[i][j], dp[i - zeroCount][j - oneCount] + 1),而且是在for循环里面更新

解答:

class Solution {
    public int findMaxForm(String[] strs, int m, int n) {
        int[][] dp = new int[m + 1][n + 1];
        for(String s : strs) {
            int zeroCount = 0;
            int oneCount = 0;
            for(char ch : s.toCharArray()) {
                if(ch == '0') {
                    zeroCount++;
                }
                if(ch == '1') {
                    oneCount++;
                }
            }
            for(int i = m; i >= zeroCount; i--) {
                for(int j = n; j >= oneCount; j--) {
                    dp[i][j] = Math.max(dp[i][j], dp[i - zeroCount][j - oneCount] + 1);
                }
            }
        }
        return dp[m][n];
    }
}

相关推荐

  1. Day46 动态规划part08 139.单词拆分 多重背包

    2024-04-04 04:42:01       38 阅读
  2. 代码随想录 day44 第九章 动态规划 part06

    2024-04-04 04:42:01       15 阅读
  3. Day42- 动态规划part10 一、买卖股票的最佳时机

    2024-04-04 04:42:01       37 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-04 04:42:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-04 04:42:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-04 04:42:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-04 04:42:01       20 阅读

热门阅读

  1. 【linux】sed的用法

    2024-04-04 04:42:01       13 阅读
  2. LeetCode 27.移除元素

    2024-04-04 04:42:01       14 阅读
  3. 【c++基础】数池塘(八方向)

    2024-04-04 04:42:01       16 阅读
  4. 4/4 清明work

    2024-04-04 04:42:01       13 阅读
  5. 什么是设计模式?使用英雄联盟来介绍设计模式

    2024-04-04 04:42:01       16 阅读
  6. “八皇后”问题——回溯+深搜

    2024-04-04 04:42:01       17 阅读
  7. 程序员的前景和未来

    2024-04-04 04:42:01       13 阅读