这道题目跟 01 背包很像,只不过实在 01 背包的基础上加上了一个重量限制。
01 背包的动态转移方程fi, j = max (fi − 1, j, fi − 1, j − vi + wi)fi, j = max (fi − 1, j, fi − 1, j − vi + wi)
那么这个多了个重量,那么可以再开一维,变成三维fi, j, k = max (fi − 1, j, k, fi − 1, j − vi, k − mi + wi)fi, j, k = max (fi − 1, j, k, fi − 1, j − vi, k − mi + wi)同 01 背包,它也可以压缩亿下空间,于是变成了fj, k = max (fj − vi,k − mi,fj, k)fj, k = max (fj − vi,k − mi,fj, k)
动态转移方程出来了,那么写代码也就轻松了。
题目
有 NN 件物品和一个容量是 VV 的背包,背包能承受的最大重量是 MM。
每件物品只能用一次。体积是 vivi,重量是 mimi,价值是 wiwi。
求解将哪些物品装入背包,可使物品总体积不超过背包容量,总重量不超过背包可承受的最大重量,且