#include<bits/stdc++.h>
using namespace std;
int v[105],w[105],dp[105][1005];
int main(){
int t,m;
cin>>t>>m;
for(int i=1;i<=m;i++){
cin>>v[i]>>w[i];
}
for(int i=1;i<=m;i++){
for(int j=1;j<=t;j++){
if(v[i]>j)dp[i][j]=dp[i-1][j];
else dp[i][j]=max(dp[i-1][j],dp[i-1][j-v[i]]+w[i]);
}
}
cout<<dp[m][t]<<endl;
return 0;
}
相似版 开心的金明
#include<bits/stdc++.h>
using namespace std;
const int maxn=3e4+5;
int v[maxn],w[maxn],dp[maxn][maxn];
int main(){
int n,m;
cin>>n>>m;
for(int i=1;i<=m;i++){
cin>>v[i]>>w[i];
}
for(int i=1;i<=m;i++){
for(int j=n;j>=1;j--){
if(v[i]>j)dp[i][j]=dp[i-1][j];
else dp[i][j]=max(dp[i-1][j],dp[i-1][j-v[i]]+w[i]*v[i]);
}
}
cout<<dp[m][n];
return 0;
}