#include<bits/stdc++.h>
using namespace std;
long long n,W,ans;
struct node{
long long w,v;
} a[110];
bool cmp(node a,node b){
return a.v>b.v;
}
int main(){
cin>>n>>W;
for(int i=1;i<=n;i++){
cin>>a[i].w>>a[i].v;
}
sort(a+1,a+n+1,cmp);
for(int i=1;i<=n;i++){
if(a[i].w<=W) W-=a[i].w,ans+=a[i].v;
}
cout<<ans<<endl;
}
为什么AC了