01揹包問題

2021-08-18 12:20:48 字數 2303 閱讀 9921

01

揹包問題:

給定 n 種物品和乙個容量為 c 的揹包,物品 i 的重量是 wi,其價值為 vi 。

問:應該如何選擇裝入揹包的物品,使得裝入揹包中的物品的總價值最大?

type 1:

解決辦法:宣告乙個 大小為  dp[n][c] 的二維陣列,表示從第1個到第i個物品中挑選出總重量不超過j的物品時總價值的最大值,那麼我們可以很容易找出 它的

狀態轉移方程

:dp[ i ] [ j ]= max(dp[i-1] [ j ],dp[i-1] [j-w[i ]]+v[ i ])  if ( j>=w[ i ])

dp[ i ] [ j ]=dp[ i-1 ][ j ];  if ( j

(1)       

j < w[i]

的情況,這時候揹包容量不足以放下第 i 件物品,只能選擇不拿

dp[ i ][j ] = dp[ i-1 ][ j ].

(2)       

j>=w[i]

的情況,這時揹包容量可以放下第 i 件物品,我們就要考慮拿這件物品是否能獲取更大的價值。

如果拿取,dp[i ][ j ]=dp[ i-1 ][ j-w[ i ] ] + v[ i ]。 這裡的dp[ i-1 ][j-w[ i ] ]指的就是考慮了前i-1件物品,揹包容量為j-w[i]時的最大價值,也是相當於為第i件物品騰出了w[i]的空間。

如果不拿,dp[ i ][ j ] = dp[ i-1][ j ] , 同(1)

究竟是拿還是不拿,自然是比較這兩種情況那種價值最大。

#include#include#includeusing namespace std;

int main()

; ///為便於讀者閱讀,初始化

int w=;

int n=6,c=12;

for(int i=1;i<=n;i++) ///從第1個到第i個物品中挑選出總重量不超過j的物品時總價值的最大值

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

printf("%d\n",dp[n][c]); ///總價值

return 0;

}

type 2:

解決辦法:宣告乙個 大小為  dp[n+1][c]的二維陣列,表示從第

1個到第

i+1個物品中挑選出總重量不超過j的物品時總價值的最大值(也可以看成從前往後推

),那麼我們可以很容易找出 它的狀態轉移方程:

#include#include#includeusing namespace std;

int main()

; int w=;

int n=6,c=12;

int dp[20][20];

memset(dp,0,sizeof(dp));

for(inti=1;i<=n;i++) ///從第1個到第i+1個物品中挑出總重量不超過j的物品時,總價值的最大值

;int w=;

int n=6,c=12;

int dp[20];

memset(dp,0,sizeof(dp));

for(int i=1;i<=n;i++) ///面對於前i個物品,能獲得的最大容量

}printf("%d\n",dp[c]);

return 0;

}

type 4

:解決辦法:宣告乙個 大小為  dp[n][c] 的二維陣列,表示從第

i個到第

n個物品中挑選出總重量不超過j的物品時總價值的最大值(可看成從後往前推

,那麼我們可以很容易找出 它的

狀態轉移方程

:dp[ i ] [ j ]= max(dp[i+1] [ j ],dp[i+1] [j-w[i ]]+v[ i ])  if ( j>=w[ i ])

dp[ i ] [ j ]=dp[ i+1 ][ j ];  if ( j

#include#include#includeusing namespace std;

int main()

; int w=;

int n=6,c=12;

int dp[20][20];

memset(dp,0,sizeof(dp));

for(int i=n;i>=1;i--) ///從第i個開始到第n個為止,挑選總重量小於j時,總價值的最大值

for(int j=1;j<=c;j++)///可看成從後往前推

{if(j

揹包問題 01揹包問題

n個物品,總體積是v,每個物品的體積的vi,每個物品的最大價值是wi,在不超過v的體積下求最大價值 eg揹包容積為 5 物品數量為 4 物品的體積分別為 物品的價值分別為 思路定義乙個二位陣列int f new int n 1 v 1 f i j 就表示在1 i個物品中選取體積小於v的情況的最大價值...

揹包問題 01揹包

有n件物品和乙個容量為v的揹包。第i件物品的重量是c i 價值是w i 求解將哪些物品裝入揹包可使價值總和最大。01揹包中的 01 就是一種物品只有1件,你可以選擇放進去揹包即1,也可以選擇不放入揹包中即0。include include using namespace std const int ...

揹包問題(01揹包)

1085 揹包問題 在n件物品取出若干件放在容量為w的揹包裡,每件物品的體積為w1,w2 wn wi為整數 與之相對應的價值為p1,p2 pn pi為整數 求揹包能夠容納的最大價值。input 第1行,2個整數,n和w中間用空格隔開。n為物品的數量,w為揹包的容量。1 n 100,1 w 10000...