多重揹包問題

2021-10-04 04:20:28 字數 1324 閱讀 7874

問題描述:有乙個容積為v的揹包,同時有n種物品,有對應種類的體積w和價值v,且每種物品k件;求該揹包最多能裝下的物品價值總和。

分析問題:

將完全揹包問題轉換為0-1揹包問題,揹包對每種物品能裝入min件,所以轉換為0-1揹包問題則物品總數n為

狀態描述:dp[i][j]表示第i件物品對於當前占用容量為j的價值狀態,其中1<=i<=n,0<=j<=v;

狀態分析:第i件物品是否加入揹包,

(1)加入,dp[i][j]等於dp[i-1][j-w]+v,第i-1件相對於j-wi的占容最大價值的最大價值加第i件價值;

(2)   沒加入,d[i][j]等於dp[i-1][j],即與第i-1件到j占容的最大價值;

狀態轉換:

轉換為一維:

轉換結果:dp[v],第n件物品到佔容為v的最大價值狀態,即完全揹包問題的最優價值總和。

時間複雜度分析:

測試資料集:

18 2

4 100 2

2 100 4

狀態矩陣:

0 0 0 100 100 100 100 100 

0 0 0 100 100 100 100 200 

0 100 100 100 100 200 200 200 

0 100 100 200 200 200 200 300 

0 100 100 200 200 300 300 300 

0 100 100 200 200 300 300 400 

code(轉換為0-1) :

#include #include #include using namespace std;

int main();

vectordp(101,0);

vectorgoods(1,);//物品總數

int w,v,k;

cin>>c;

while(c--));

} for(int j=0;j<=v;j++)

for(int i=1;i<=n;i++)

for(int j=1;j<=v;j++)

cout簡化0-1**:

struct goodsclass

for(int i=i;igoodsclass[i].w;j--)

}}//求多重揹包

以上簡化時間複雜度為基於上述0-1簡化**,可實現對完全揹包問題求解:

for(int i=1;i<=n;i++)}}

最後建議:求揹包問題都轉換為0-1揹包問題,若需要優化則再考慮優化。

多維多重揹包問題 多重揹包問題

悼念512汶川大 遇難同胞 珍惜現在,感恩生活 急!災區的食物依然短缺!為了挽救災區同胞的生命,心繫災區同胞的你準備自己採購一些糧食支援災區,現在假設你一共有資金n元,而市場有m種大公尺,每種大公尺都是袋裝產品,其 不等,並且只能整袋購買。請問 你用有限的資金最多能採購多少公斤糧食呢?後記 人生是乙...

揹包問題 多重揹包

有n種物品和乙個容量為w的揹包。第i種物品最多有n i 件可用,每件重量是w i 價值是v i 求解將哪些物品裝入揹包可使這些物品的重量總和不超過揹包容量,且價值總和最大。1.使用三重迴圈進行遞推 狀態轉移式為 dp i j max 關鍵 如下 void solve printf d n dp n ...

多重揹包問題

有n種物品和乙個容量為v的揹包。第i種物品最多有n i 件可用,每件費用是c i 價值是w i 求解將哪些物品裝入揹包可使這些物品的費用總和不超過揹包容量,且價值總和最大。這題目和完全揹包問題很類似。基本的方程只需將完全揹包問題的方程略微一改即可,因為對於第i種物品有n i 1種策略 取0件,取1件...