Day45 动态规划part05

LC1049最后一块石头重量II(未掌握)

  1. 未掌握分析:其实本题跟LC416分割等和子集类似,本质上题目的要求是尽量让石头分成重量相同的两堆,相撞之后剩下的石头最小,也就是01背包问题
  2. weight和value都是stones数组,题目可以看成是target=sum/2,即求背包容量是target所装石头的value是多少。
  3. target = sum / 2 因为是向下取整,所以sum - dp[target] 一定是大于等于dp[target]的。
  4. 代码

LC494目标和(未掌握)

  1. 未能够将题意转换为01背包问题
  2. 其实题目也就是将数组分为两堆,+一堆,-一堆,然后+的sum:left和-的sum:right,能够又left-right=target,但又因为left+right=sum,因此有left = (sum+target)/2
  3. 因此题目就转化为,装满容量为left的背包,有几种方法
  4. dp[j] 表示:填满j(包括j)这么大容积的包,有dp[j]种方法
  5. 递推公式:当来到了nums[i]有dp[j] += dp[j-nums[i]]
  6. 初始化,dp[0]=1;
  7. 一些极端条件需要判断
    • 如果abs(target)>sum,一定是没有办法
    • 如果sum+target不能够整除2也是没有办法的
  8. 代码:

LC474一和零(未掌握)

  1. 本质上其实还是01背包问题,但是不同的是背包被分为了两个容量,一个是1容量m另外一个是0容量n
  2. strs中的每一个string就是一个货物
  3. dp[i][j]表示抓满i个1容量和j个0容量的背包最大的子集个数是dp[i][j]
  4. 递推公式:dp[i][j] = dp[i-oneNums][j-zeroNums]+1;
  5. 需要判断一下每个货物中0和1的个数
相关推荐
小O的算法实验室6 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生8 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿8 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz8 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能8 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****8 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能8 小时前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能8 小时前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo8 小时前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ08 小时前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法