完全背包----两个for循环的先后问题

这篇文章主要是讲完全背包问题中,什么情况下两个for循环的位置不能交换。


点击打开链接(完全背包问题----思想的理解)中我们提到,完全背包一维数组的实现的两个for循环是可以交换顺序的。

伪代码分别如下所示:


方式一:《背包九讲》基于01背包问题推导出来的,还记得和01背包一维数组实现的区别吗?

f[0] =0;

for    i:1->n

    do  for j:c[i]->C

          f[j] = max(f[j],f[j-c[i]+w[i]])



方式二:《算法竞赛入门》基于DAG推导出

f[0] = 0

for   i:1->C

      do for j:1->n

          if(i>=c[j] && f[i]>f[i-c[j]]+w[i])  f[i] =f[i-c[j]]+w[i];


完全背包问题的要求是要求求出装满背包时的最大重量,在这种情况下,上述两种for循环都是可以的。


但是我们现在来换一个问题:UVa中的674硬币找零问题:

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值