多重背包问题(二进制优化)

Posted jason66661010

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多重背包问题(二进制优化)相关的知识,希望对你有一定的参考价值。

有N种物品和一个容量为V的背包。第i种物品最多有p[i]件可用,每件费用是w[i],价值是v[i]v[i]v[i]。求解将哪些物品装入背包可使这些物品的费用总和不超过背包容量,且价值总和最大。

具体转换为01背包的策略:二进制拆分

将第i种物品分成若干件物品,其中每件物品有一个系数,这件物品的费用和价值均是原来的费用和价值乘以这个系数。

例如意见物品的p【i】为13,则要分为4件物品,这四件物品的系数分别是1 2 4 6,则四件物品的占用空间与价值均变为原来的1 2 4 6倍

代码:

for (int i = 1; i <= n; i++) 
{
    int num = min(p[i], V / w[i]);//比较选取拥有的个数p[i]、物品理论可选取得最大值 V / w[i]中较小的一个
    for (int k = 1; num > 0; k <<= 1) //k是左移,开始是1 ,左移一位变为2 接着4 8……
	{
        if (k > num) k = num;
        num -= k;
        for (int j = V; j >= w[i] * k; j--)
            f[j] = max(f[j], f[j - w[i] * k] + v[i] * k);//都要*k
    }
}

以上是关于多重背包问题(二进制优化)的主要内容,如果未能解决你的问题,请参考以下文章

51nod 1086 背包问题 V2(二进制优化多重背包)

POJ-1276 Cash Machine 多重背包 二进制优化

多重背包问题(二进制优化)

多重背包问题的二进制优化

2/17 01背包+完全背包+多重背包(二进制优化)+二位费用背包+dfs

AcWing 5. 多重背包问题 II(二进制优化)