AcWing 2. 01背包问题
原题链接
简单
作者:
pakchoiii
,
2021-01-19 13:50:59
,
所有人可见
,
阅读 479
C++ 代码
#include <iostream>
using namespace std;
const int N = 1010;
int n, m; //n物品数量,m背包容量
int v[N], w[N]; //v[i]第i件物品的体积,w[i]第i件物品的价值s
int dp[N][N];
int main() {
cin >> n >> m;
for(int i = 0; i < n; i++) cin >> v[i] >> w[i];
//初始化
for (int j = m; j >= v[0]; j--) {
dp[0][j] = dp[0][j - v[0]] + w[0];
}
for(int i = 1; i < n; i++) { //遍历物品
for(int j = 0; j <= m; j++) { //遍历背包容量
dp[i][j] = dp[i-1][j];
if(j>=v[i]) dp[i][j] = max(dp[i-1][j], dp[i-1][j-v[i]]+w[i]);
}
}
cout << dp[n-1][m] << endl;
return 0;
}