代码求调:
#include <bits/stdc++.h>
using namespace std;
int f[30005],v[30],p[30];
int main(){
int n,m;
cin>>n>>m;
for(int i=1;i<=m;i++){
cin>>v[i]>>p[i];
p[i]*=v[i];
}
for(int i=1;i<=m;i++){
for(int j=n;j>=v[i];j--){
if(j<v[i]) f[j]=f[j-1];
f[j]=max(f[j],f[j-v[i]]+p[i]);
}
}
cout<<v[n];
return 0;
}
三个AC,其他全WA