Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
142270 | C班詹皓杰 | 0/1背包问题 | C++ | 通过 | 100 | 4 MS | 4204 KB | 418 | 2024-04-06 20:08:21 |
#include<iostream> #include<algorithm> using namespace std; int w[1010],c[1010],dp[1010][1010]; int main(){ int n,m; cin>>m>>n; for(int i = 1; i <= n; i++){ cin>>w[i]>>c[i]; } for(int i = 1; i <= n; i++){ for(int j = 1; j <= m; j++){ if(j >= w[i]){ dp[i][j] = max(dp[i-1][j-w[i]]+c[i],dp[i-1][j]); }else{ dp[i][j] = dp[i-1][j]; } } } cout<<dp[n][m]; return 0; }