72分
#include<bits/stdc++.h>
using namespace std;
int n,m;
int w[12801],d[12801];
int dp[12801];
int pre[12801];
int main(){
ios::sync_with_stdio(0),cin.tie(0);
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>w[i]>>d[i];
}
for(int i=1;i<=n;i++){
for(int j=0;j<=m;j++){
dp[i]=pre[i];
if(j>=w[i]){
dp[j]=max(dp[j],pre[j-w[i]]+d[i]);
}
}
for(int j=0;j<=m;j++){
pre[j]=dp[j];
}
}
cout<<dp[m];
return 0;
}