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

2023.8.13

分割等和子集类似,可以转化为0-1背包问题。 本题也是需要将数组元素分成两堆,区别在于本题需要使这两堆的差值最小,而之前那题是需要两堆差值为0。

使用之前的一维dp数组的思路,代码如下:

cpp 复制代码
class Solution {
public:
    int lastStoneWeightII(vector<int>& stones) {
        int sum = 0;
        for(int i=0; i<stones.size(); i++)
        {
            sum += stones[i];
        }
        int target = sum / 2;
        vector<int> dp(target + 1);
        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];
    }
};
相关推荐
阿贵---6 分钟前
C++代码规范化工具
开发语言·c++·算法
暮冬-  Gentle°14 分钟前
自定义内存检测工具
开发语言·c++·算法
ccLianLian25 分钟前
数论·欧拉函数
数据结构·算法
2501_9454248032 分钟前
C++编译期矩阵运算
开发语言·c++·算法
2301_8154829338 分钟前
C++中的类型标签分发
开发语言·c++·算法
xushichao198943 分钟前
代码生成优化技术
开发语言·c++·算法
炽烈小老头1 小时前
【每天学习一点算法 2026/03/22】前 K 个高频元素
学习·算法
leaves falling1 小时前
C++类和对象(1)
开发语言·c++
2401_873204651 小时前
模板编译期循环展开
开发语言·c++·算法
木心月转码ing1 小时前
Hot100-Day51-TT70爬楼梯
算法