题目链接


#include <bits/stdc++.h>
using namespace std;
int v[40000],w[40000],f[40000],n,m;
int main(){
cin>>n>>m;
for(int i=1;i<=m;i++)
{
int k;
cin>>w[i]>>k;
v[i]=w[i]*k;
}
for(int i=1;i<=m;i++){
for(int j=n;j>=w[i];j--)f[j]=max(f[j],f[j-w[i]]+v[i]);}
cout<<f[n]<<endl;
return 0;
}
总结
无