这篇文章主要是讲完全背包问题中,什么情况下两个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硬币找零问题: