#include<bits/stdc++.h>
using namespace std;
int main()
{
long long n,dp[60005],w[60005],c[60005],t;
cin>>n>>t;
for(int i=1;i<=n;i++){
cin>>w[i]>>c[i];
}
for(int i=1;i<=n;i++){
for(int j=t;j>=w[i];j--){
dp[j]=max(dp[j],dp[j-w[i]]+c[i]);
}
}
cout<<dp[t];
return 0;
}