整數0-1揹包問題
• 小偷有一個容量為W的揹包,有n件物品,第i個物品價值vi,且重wi。
• 目標: 找到xi使得對於所有的xi = {0, 1},sum(wi*xi) <= W, 並且 sum(xi*vi)最大。
常規思路
public class BackPack
{
static int [] w = new int[] {3, 4, 5, 7, 6}; // 每件物品的重量
static int[] v = new int[] {4, 5, 2, 8, 9}; // 每件物品的價值
static int N = w.length; // 物品的個數
final int W = 15; // 揹包的總重量
/**
* @param idx 當前遍歷的是第幾個物品
* @param S 當前物品的總重量
* @return 最大的價值
*/
int search(int idx, int S)
{
// 當前物品的總重量和大於揹包的重量
if (S > W)
{
return 0;
}
// 遍歷到最後一個物品了
if (idx >= N)
{
return 0;
}
return Math.max(search(idx+1, S + w[idx]) + v[idx], search(idx+1, S));
}
}
程式碼裡冗餘太多(有多種方法都可以使得當前物品的總重量達到S,每一種構成方式都會去算一遍),對於
當前的狀態而言,我們只關心的使用的多少,如何使用的並不關心。
改進後:
int[][] f = new int[N][W]; // 定義f(i,j):當前揹包容量 j,前 i 個物品最佳組合對應的價值;
// 初始化塊
{
for (int i=0; i<N; i++)
{
for (int j=0; j<W; j++)
{
f[i][j] = -1;
}
}
}
int search(int idx, int S)
{
// 當前物品的總重量和大於揹包的重量
if (S > W)
{
return 0;
}
// 遍歷到最後一個物品了
if (idx >= N)
{
return 0;
}
// 如果計算過
if (f[idx][S] >= 0) { // F(i, W)表示前i件物品體積為w,最大價值
return f[idx][S];
}
f[idx][S] = Math.max(search2(idx+1, S + w[idx]) + v[idx], search2(idx+1, S));
return f[idx][S];
}
迭代法:自底向上求解
int search()
{
dp[0][0] = 0;
// 賦初始值
for (int i=0; i<=W; ++i)
{
dp[0][i] = (int) Double.NEGATIVE_INFINITY; // 表示負無窮
}
for (int i=1; i<=N; ++i)
{
dp[i][0] = 0; // (先要把已知的條件填好)
for (int j=1; j<=W; ++j) // 揹包的容量的範圍
{
dp[i][j] = dp[i-1][j]; // 表示還沒選第idx件物品
if (j >= w[i]) // 表示揹包中能放進去
// 注意這裡在計算的時候要利用之前已經計算出來的狀態
dp[i][j] = Math.max(dp[i-1][j - w[i]] + v[i], dp[i-1][j]);
}
}
return dp[N][W];
}
相關文章
- leetcode題解(0-1揹包問題)LeetCode
- 【演算法】0-1揹包問題演算法
- 0-1揹包問題(動態規劃)動態規劃
- 動態規劃解0-1揹包問題動態規劃
- 動態規劃之 0-1 揹包問題詳解動態規劃
- 揹包問題(01揹包與完全揹包)
- 【動態規劃】0-1揹包問題原理和實現動態規劃
- 揹包問題
- TYVJ 1096 數字組合【0-1揹包模型】模型
- 51nod 1597 有限揹包計數問題 (揹包 分塊)
- 01揹包問題
- 01 揹包問題
- 01揹包和完全揹包問題解法模板
- 揹包九講問題
- 經典揹包問題
- 揹包問題大合集
- 部分揹包問題(挖
- 005多重揹包問題||
- 從【零錢兌換】問題看01揹包和完全揹包問題
- 揹包問題例題總結
- 【leetcode】揹包問題彙總LeetCode
- 2. 01揹包問題
- 揹包問題解題方法總結
- JavaScript中揹包問題(面試題)JavaScript面試題
- chapter12-2-揹包問題APT
- 關於各種揹包問題
- 【動態規劃】揹包問題動態規劃
- 01揹包問題的解決
- 二維費用揹包問題
- 深入剖析多重揹包問題(上篇)
- 深入剖析多重揹包問題(下篇)
- 揹包問題----動態規劃動態規劃
- 揹包計數問題的多項式最佳化
- 揹包問題的一道經典問題
- HDU Piggy-Bank(完全揹包問題)
- 動態規劃 01揹包問題動態規劃
- 【動態規劃】01揹包問題動態規劃
- 動態規劃--01揹包問題動態規劃