多重背包伪代码如下:
for i=1..N
for v=0..V
f[v]=max{f[v],f[v-weight[i]]+value[i]}
注意是顺序结构的;
01背包伪代码:
for i=1..N
for v=V..0
f[v]=max{f[v],f[v-weight[i]]+value[i]};
注意是逆序结构的;其中 v 代表当前背包的重,也就是说,v是从weight[i]或者是volumn[i]开始的
例子就拿 HDU 2602 Bone collector ------------01背包题型
以及 HDU 1114 piggy-Bank
再晒一题,因为现在貌似把多重背包弄懂了。