Run ID | 作者 | 问题 | 语言 | 测评结果 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|
46466 | zhouhuanyu 玙静 | 最大价值 | C++ | 通过 | 0 MS | 260 KB | 420 | 2024-05-04 09:16:57 |
#include <bits/stdc++.h> using namespace std; int w[55], v[55]; int dp[55][605]; int main(){ int t, m; cin >> t >> m; for(int i = 1; i <= m; i++){ cin >> w[i] >> v[i]; } for(int i = 1; i <= m; i++){ for(int j = 1; j <= t; j++){ if(j >= w[i]){ dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - w[i]] + v[i]); }else{ dp[i][j] = dp[i - 1][j]; } } } cout << dp[m][t]; return 0; }