#include <bits/stdc++.h>
using namespace std;
int w[3402 + 1], v[3402 + 1]; //w用来记录每个Bracelet的重量,v用来记录每个Bracelet的价值
int dp[12880 + 1]; //dp用来记录每个背包的最大载重量
int main()
{
int N, M;
scanf("%d%d", &N, &M);
int i, j;
for(i = 1; i <= N; i++){
scanf("%d%d", &w[i], &v[i]);
}
for(i = 1; i <= N; i++){
for(j = M; j >= w[i]; j--){
dp[j] = max(dp[j], dp[j - w[i]] + v[i]);
}
}
printf("%d\n", dp[M]);
return 0;
}
程序设计实习MOOC / 程序设计与算法(二)测验汇总(2019春季) 016
最新推荐文章于 2022-12-28 15:10:47 发布