Pagini recente » Cod sursa (job #882575) | Cod sursa (job #1499077) | Cod sursa (job #87780) | Cod sursa (job #693238) | Cod sursa (job #1392078)
#include<fstream>
#include<algorithm>
using namespace std;
ifstream f("rucsac.in");
ofstream g("rucsac.out");
int n,G,w[5005],p[5005],ind[5005];
inline int cmp(int a,int b){ return w[a]*p[a]>w[b]*p[b];}
int main()
{
f>>n>>G;
for (int i=1; i<=n; i++)
f>>w[i]>>p[i];
for(int i=1;i<=n;i++)
ind[i]=i;
sort(ind+1,ind+n+1,cmp);
int x=0,sol=0;
for(int i=1;i<=n;i++)
if(x+w[ind[i]]<=G)
{
x+=w[ind[i]];
sol+=p[ind[i]];
}
g<<sol<<'\n';
g.close();
return 0;
}