当前位置: 首页> 健康> 美食 > 代码随想录 第九章 动态规划part04 1049. 最后一块石头的重量 II

代码随想录 第九章 动态规划part04 1049. 最后一块石头的重量 II

时间:2025/7/14 5:33:16来源:https://blog.csdn.net/qq_53524614/article/details/142218236 浏览次数:0次

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

class Solution {
public:int lastStoneWeightII(vector<int>& stones) {int sum=0;for (int i = 0; i < stones.size(); i++) sum+=stones[i];vector<int> w(sum / 2 + 1, 0);for (int i = 0; i < stones.size(); i++){for (int j = w.size() - 1; j >= 0; j--){if (j - stones[i] >= 0) w[j] = max(w[j], w[j - stones[i]] + stones[i]);}}return sum - 2 * w[sum / 2];}
};

这题其实与之前的将数组分割为两个和一样的部分是一样的,将石头分割为两个重量尽可能接近的部分,两部分之和就是所求的答案,所以问题也就可以转化为石头总重/2大小的背包问题。在使用一维背包中有一个注意点,就是背包的更新要从右向左,因为动态规划需要的信息与上一轮迭代的的结果中背包容量较小的部分有关,如果从左至右迭代,就会导致之后迭代所需的信息出现错误。

代码随想录 第九章 动态规划part04 

关键字:代码随想录 第九章 动态规划part04 1049. 最后一块石头的重量 II

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: