算法基础课:动态规划之背包问题

首先动态规划,应该理解为一个递推的过程,很多时候对于动态规划来说都应该是从前向后递推的一个过程。但是思考的方式还是应该按照递归的思想来去思考,比如说按照集合划分,状态表示,状态表示又可以划分成状态表示的东西是什么?状态表示的条件是什么,属性又是什么?状态计算就是正常的一个递推的过程,思考方式是该属性可以来源于哪些部分,然后然后以递推的方式进行即可。
01背包:每个物体只有选与不选。
完全背包:每个物体可以选择无数次。
多重背包:每个物体只能选择有限次。
分组背包:分成若干组,每次只能从每组之中选择一个(类似01背包)
其实都是推公式加变形的一个过程,具体的东西需要自己一步步推导。
这里重点讲下多重背包的二进制优化问题。
原始问题的时间复杂度O(NMS)变成O(NMlogs)
核心原理就是:对于任意的数都可以用二进制表示:
举例:对于200可以用1,2,4,。。。。64来表示1-127同时再加上一个C特别注意此C小于128。
然后原始的问题可以转换成:把S转成此种表示方式,存入到V[I]和W[I]数组中去,然后原始的问题就可以转换成0,1背包模型来解决。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值