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 )
全部评论

相关推荐

02-07 10:52
复旦大学 Java
混子不想混:非常能理解,感觉他们就靠着入行早,打压新人一样。我这个公司也是,天天干的累死累活,然后绩效打C,合着让新人被绩效,像是年底攒棺材本一样。总是打击之后,还会让人开始自我怀疑,是不是我努力的还不够,实际上并不是,就是他们不做人,故意打压新人。
点赞 评论 收藏
分享
在喝茶的杨桃很郁闷:我简单喵两句: 1.如果不是实在没东西写不要写熟悉async await这些语法层面的东西 2.也不要写熟悉HTTP,因为http内容很多,稍微深挖一点你不会的话会让人有一种“原来你简历上面的东西都没有完全掌握”的感觉,容易给自己挖坑 3.自我评价可以删了 4.我在复习明天的面试,先mark,后面再回来继续建议
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务