动态规划-背包问题——1049.最后一块石头的重量II

1.题目解析

题目来源

|-----------------------------------------------------------------------------------------------------------------------|
| 1049.最后一块石头的重量II------力扣 |

测试用例

2.算法原理

首先需要将该问题转化为0-1背包问题后再做分析

1.状态表示

根据数学中的知识我们知道将一个数字分为两个子数后求这两个子数的最小差值,那么就要求这两个子数尽可能接近于原数字的一半,那么就一定会出现一大一小两个数或者两个相等的数,这时就需要去找总和不大于原数字一半的数字,然后找到另一半,用另一半减去找到的数字即可,所以需要二维dp表,第一个下标表示已经寻找数字的区间,第二个下标表示此时已寻找并选择数字的总和,即dp[i][j]:在[1,i]区间选择的数字总和不大于(小于或等于) j 的总和大小

2.状态转移方程

首先依旧是背包问题的思路,对最后一个位置进行分类讨论,首先判断当第i个位置不会选取,此时就找到dp[i-1][j],判断此时的方法数;然后判断选取第i个位置的数,此时就需要寻找到dp[i-1][j-nums[i-1]]这个位置的dp表的值,然后加到总方法数中去,当然需要判断j>=nums[i-1]

3.初始化

4.填表顺序

从上到下,每一行从左到右

5.返回值

返回两个子数相减,也就是sum - dp[n][aim]*2(sum - dp[n][aim] 与 dp[n][aim]两个子数)

3.实战代码

cpp 复制代码
class Solution {
public:
    int lastStoneWeightII(vector<int>& stones)
    {
        int sum = 0;
        for(auto e : stones)
        {
            sum += e;
        }    
        int aim = sum / 2;
        int n = stones.size();
        vector<vector<int>> dp(n+1,vector<int>(aim+1));

        for(int i = 1;i <= n;i++)
        {
            for(int j = 0;j <= aim;j++)
            {
                dp[i][j] = dp[i-1][j];
                if(j >= stones[i-1])
                {
                    dp[i][j] = max(dp[i][j],
                    dp[i-1][j - stones[i-1]] + stones[i-1]);
                }
            }
        }

        return sum - dp[n][aim] - dp[n][aim];
    }
};

代码解析

空间优化

相关推荐
JMchen123几秒前
Android NDK开发从入门到实战:解锁应用性能的终极武器
android·开发语言·c++·python·c#·android studio·ndk开发
weixin_457760001 分钟前
深入解析 Beam Search:从原理到实践的高效解码算法
python·算法
ulimate_2 分钟前
anygrasp算法:调研与使用
算法
名字不相符15 分钟前
2026年3月27日NSSCTF之[SWPU 2019]漂流记的马里奥
学习·ctf·萌新
小羊羔heihei32 分钟前
Python列表操作全攻略
经验分享·笔记·python·学习·其他·交友
愣头不青39 分钟前
96.不同的二叉搜索树
数据结构·算法·leetcode
AI科技星1 小时前
光速螺旋量子几何统一场论——基于 v ≡ c 公理的四大基本力全维度求导证明与精准数值验证
c语言·开发语言·人工智能·算法·机器学习·平面
ab1515171 小时前
3.27完成3(指针)、13、41、44(指针)、50、51、95、96、97
算法
程序猿编码1 小时前
隐匿注入型ELF加壳器:原理、设计与实现深度解析(C/C++ 代码实现)
c语言·网络·c++·elf·代码注入
AI成长日志1 小时前
【强化学习专栏】深度强化学习技术演进:DQN、PPO、SAC的架构设计与训练优化
人工智能·算法·架构