Day35| 动规和背包变形

今天三道题目,可以说分别是背包问题的不同变形

三个模型

  • 已知每个物品的重量和价值。背包空间大小为Space,求放入物品的最大的价值。变形一 在和的上限不超过 half 的情况下的最大和。
  • 已知每个物品的重量和价值。背包空间大小为Space,求装满背包的方法数量
  • 已知每个物品的重量和价值。背包空间大小为Space,求背包最大可以放的数量。

最后一块石头的重量

这题实际上求得是 在和的上限不超过 half 的情况下的最大和。

基础背包模型求得是 空间和上限不超过 half 的情况下的最大价值和。

观察可以发现,如果将重量和价值相等的话,我们可以得到一个化简的式子也就是题目所有的内容。转换成代码就是这样

目标和

这题实际上就得是一个序列里面和为 sum 的个数。显然遍历回溯是可以解的。同时这有个最优子结构。

dp [i] [space] = dp[i-1] [space] + dp[i-1][space-space[i]]

对每个物品进行遍历即可。 对这个问题进行抽象我们可以得到 这样的背包问题。

  • 已知每个物品的重量和价值。背包空间大小为Space,求装满背包的方法

474.一和零

这题实际上问的是

  • 已知每个物品的重量和价值。背包空间大小为Space,求背包最大可以放的数量。
  • dp [i] [space] = max( dp[i-1] [space] , dp[i-1][space-space[i]] +1 )
全部评论

相关推荐

不愿透露姓名的神秘牛友
10-30 10:32
美团 后端开发 23k 双非本,985硕
程序员小白条:薪资请匿名,要么过一段时间发
点赞 评论 收藏
分享
躺尸修仙中:因为很多92的也去卷中小厂,反正投递简历不要钱,面试不要钱,时间冲突就推,不冲突就面试积累经验
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务