Pagini recente » Monitorul de evaluare | Cod sursa (job #2365963) | Cod sursa (job #1761933) | Cod sursa (job #270444) | Cod sursa (job #2389398)
#include<bits/stdc++.h>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int c[500],g[1000],ef[1000],gv,man,castig=0;
int n,i,man1,inv,ordine[9];
main()
{
fin>>gv;
fin>>n;
for(i=1;i<=n;i++)
{
fin>>c[i];
fin>>g[i];
ordine[i]=i;
ef[i]=c[i]/g[i];
}
do
{
inv=0;
for(i=1;i<=n-1;i++)
if(ef[i]<ef[i+1])
{
man=ef[i];
ef[i]=ef[i+1];
ef[i+1]=man;
man=c[i];
c[i]=c[i+1];c[i+1]=man;
man=g[i];
g[i]=g[i+1];g[i+1]=man;
inv=1;
man1=ordine[i];
ordine[i]=ordine[i+1];
ordine[i+1]=man1;
}
}
while(inv);
i=1;
while(gv>0&&i<=n)
{
if(gv>g[i])
{
gv-=g[i];
castig+=c[i];
}
i++;
}
fout<<castig;
}