#include<iostream>
#include<algorithm>
using namespace std;
int v[1010],w[1010];
int f[1010];
int main(){
int n,V;
cin>>n>>V;
for(int i=1;i<=n;i++){
cin>>v[i]>>w[i];
}
for(int i=1;i<=n;i++){
for(int j=V;j>=v[i];j--){
f[j]=max(f[j],f[j-v[i]]+w[i]);
}
}
cout<<f[V];
}