有感而发,标准DP(虽然写过了)
#include<bits/stdc++.h>
using namespace std;
int n,m;
int w[1005],v[1005];
int f[1005][1005];
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>w[i]>>v[i];
}
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
f[i][j]=f[i-1][j];
if(j>=w[i]){
f[i][j]=max(f[i-1][j],f[i-1][j-w[i]]+v[i]);
}
}
}
cout<<f[n][m];
}