提交时间:2024-04-06 17:42:53

运行 ID: 142245

#include <bits/stdc++.h> using namespace std; int m,n,w[1001],c[1001]; int f[1001][1001]; int main() { cin>>m>>n; for(int i=1; i<=n; i++) { scanf("%d%d",&w[i],&c[i]); } for(int i=1; i<=n; i++) { for(int j=1; j<=m; j++) { if(j>=w[i]) { f[i][j]=max(f[i-1][j-w[i]]+c[i],f[i-1][j]); } else { f[i][j]=f[i-1][j]; } } } printf("%d\n",f[n][m]); return 0; }