代码随想录算法训练营Day-36动态规划04 | 1049. 最后一块石头的重量 II、494. 目标和、474.一和零

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

向背包问题的转化方式:

根据题意,最终的结果就是把石头分成最接近的两堆,然后做差。所以转化为背包问题就是,往容器为sum/2的背包里面放最大重量的石头,也就是把石头价值设为重量。最终dpsum/2的值就是分成的两堆中比较小的堆重 ,然后sum-dpsum/2就是比较大的堆重,二者做差就是最终结果。

cpp 复制代码
class Solution {
public:
    int lastStoneWeightII(vector<int>& stones) {
        vector<int> dp(15001,0);
        int sum=0;
        for(int i:stones) sum+=i;
        int target = sum/2;
        for(int i=0;i<stones.size();++i){
            for(int j=target;j>=stones[i];--j){
                dp[j]=max(dp[j],dp[j-stones[i]]+stones[i]);
            }
        }

        return sum-dp[target]-dp[target];
    }
};

494. 目标和

转化成背包问题的思路:

本题可化为划分两个子集的问题,left为加号集总和,right为减号集总和,求其中一个集合的放物品方式即可得到结果(因为一个集合固定了,另外一个集合也是固定的);

两个公式:left+right=sum;left-right=target;

推导出:left=(sum+target)/2;

所以left可作为背包的最大容量,然后nums中的元素即为物品,转化为了背包问题

动规五部曲-一维:

1.dpj的含义:容量为j的背包,在i个物品下选取,装满背包有多少种方式

2.递推公式:dpj+=dpj-nums\[i]

解释:dpj 的含义是前 i-1 个物品装满容量 j 的方式数量;dpj-nums\[i] 是前 i-1 个物品装满容量 j-numsi 的方式数量。把dpj拆分为两种情况

(1) 选择当前物品 numsi ,那么这些能够装满 j-numsi 的方案,每一种都可以再加上当前物品,变成一种装满容量 j 的新方案。所以当前 dpj 需要加上 dpj-nums\[i] 这一部分。

(2) 不选择当前物品numsi,前面物品已经能够装满 j 的方案数-dpj(上一循环的)

因此最终 dpj 就等于"不选当前物品的就能装满j的方案数"加上"选择当前物品能装满j的方案数"。

3.初始化方式:只需dp0=1,其余为0,方便后面容量进行递推,例:有一个数字1,容量为1,所以有一种方法,按照递推公式dp1+=dp0,所以需要dp0=1,否则dp所有元素都是0了。

4.遍历顺序:和0-1背包问题一样,为了避免重复选取物品和能够放入多个物品,需要先物品后背包+倒序遍历

cpp 复制代码
class Solution {
public:
    int findTargetSumWays(vector<int>& nums, int target) {
        int sum = 0;
        for(int i:nums) sum+=i;
        if (abs(target) > sum) return 0;
        if((sum+target) % 2 !=0) return 0;
        int rongliang = (sum+target)/2;

        vector<int> dp(rongliang+1,0);
        dp[0]=1;

        for(int i=0;i<nums.size();i++){
            for(int j=rongliang;j>=nums[i];j--){
                dp[j] += dp[j-nums[i]];
            }
        }

        return dp[rongliang];
    }
};

474.一和零


相关推荐
BothSavage2 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn2 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽4 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说20 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法