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];
    }
};
相关推荐
J ..3 分钟前
C++ 多线程编程基础与 std::thread 使用
c++
你的冰西瓜3 分钟前
C++标准模板库(STL)全面解析
开发语言·c++·stl
阿昭L5 分钟前
leetcode链表相交
算法·leetcode·链表
闻缺陷则喜何志丹23 分钟前
【计算几何】仿射变换与齐次矩阵
c++·数学·算法·矩阵·计算几何
chen_ever26 分钟前
Protobuf详解(从安装到实战)
c++·rpc·信息与通信
liuyao_xianhui28 分钟前
0~n-1中缺失的数字_优选算法(二分查找)
算法
hmbbcsm1 小时前
python做题小记(八)
开发语言·c++·算法
机器学习之心1 小时前
基于Stacking集成学习算法的数据回归预测(4种基学习器PLS、SVM、BP、RF,元学习器LSBoost)MATLAB代码
算法·回归·集成学习·stacking集成学习
图像生成小菜鸟1 小时前
Score Based diffusion model 数学推导
算法·机器学习·概率论
再睡一夏就好1 小时前
深入Linux线程:从轻量级进程到双TCB架构
linux·运维·服务器·c++·学习·架构·线程