POJ-3624-Charm Bracelet-简单0/1背包、动态规划、DP

简单的0/1背包问题,用动态规划即可简单求解。
以下一段话摘自Slyar.
==========================================================
Slyar:标准的01背包,动态转移方程如下。其中dp[i,j]表示的是前i个物品装入容量为j的背包里所能产生的最大价值,w[i]是第i个物品的重量,d[i]是第i个物品的价值。如果某物品超过背包容量,则该物品一定不放入背包,问题变为剩余i-1个物品装入容量为j的背包所能产生的最大价值;否则该物品装入背包,问题变为剩余i-1个物品装入容量为j-w[i]的背包所能产生的最大价值加上物品i的价值d[i]...恩,多清晰...


==========================================================

先上一个用二维数组求解的代码,这个代码比较容易理解。为了求深理解,可以在纸上自己试着计算下这个二维数组dp。

由于OJ上memory所限,上面代码提交上去会MLE的。在纸上计算dp过程中,发觉dp设置成n行的二维数组实际上没有必要,因为在计算dp第i行时只用到dp第i-1行的数据,而且到了最后,前面n-1行都没用的。因此,完全可以用一维数组进行计算。但要注意,应从后住前计算dp,否则dp的数据会被新计算的值覆盖,导致不正确。

观察二重for循环,可以发觉其实还可以继续进一步优化下。最终的程序版本为:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值