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];
    }
};
相关推荐
NAGNIP9 小时前
万字长文!回归模型最全讲解!
算法·面试
知乎的哥廷根数学学派9 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
txinyu的博客10 小时前
解析业务层的key冲突问题
开发语言·c++·分布式
666HZ66611 小时前
数据结构2.0 线性表
c语言·数据结构·算法
SmartRadio11 小时前
ESP32添加修改蓝牙名称和获取蓝牙连接状态的AT命令-完整UART BLE服务功能后的完整`main.c`代码
c语言·开发语言·c++·esp32·ble
余瑜鱼鱼鱼11 小时前
Java数据结构:从入门到精通(十二)
数据结构
实心儿儿11 小时前
Linux —— 基础开发工具5
linux·运维·算法
charlie11451419112 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
清木铎13 小时前
leetcode_day4_筑基期_《绝境求生》
算法
清木铎13 小时前
leetcode_day10_筑基期_《绝境求生》
算法