Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
67291 | 陶俊宸 | 开心的金明 | C++ | 通过 | 100 | 2 MS | 2832 KB | 374 | 2023-01-12 15:59:33 |
#include<cstdio> #include<algorithm> using namespace std; int n,m,v[26],p[26],dp[26][30001]; int main(){ scanf("%d %d",&n,&m); for(int i=1;i<=m;i++) scanf("%d %d",&v[i],&p[i]); for(int i=1;i<=m;i++){ for(int j=1;j<=n;j++){ dp[i][j]=dp[i-1][j]; if(j>v[i]) dp[i][j]=max(dp[i][j],dp[i-1][j-v[i]]+v[i]*p[i]); } } printf("%d",dp[m][n]); return 0; }