AcWing 3
#include<bits/stdc++.h>
using namespace std;
const int N=1005;
int f[N],v[N],w[N];
int n,m;
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++)
scanf("%d%d",v+i,w+i);
for(int i=1;i<=n;i++)
for(int j=v[i];j<=m;j++)
f[j]=max(f[j],f[j-v[i]]+w[i]);
cout<<f[m];
}