Cod sursa(job #1808212)

Utilizator Cristi9944Anghel Cristian Cristi9944 Data 17 noiembrie 2016 15:08:58
Problema Problema rucsacului Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include <iostream>
#include <stdio.h>
#include<algorithm>
using namespace std;
FILE *in,*out;
int n,gmax;
int ct=0;
struct obiect
{
    int g;int v;
}r[1001];
bool cmp( obiect a,obiect b)
{
    return(a.v * b.g> a.g * b.v);
}
int main()
{   in=fopen("rucsac.in","r");
    out=fopen("rucsac.out","w");
    int i;
    fscanf(in,"%d %d",&n,&gmax);
    for(i=1;i<=n;i++)
        fscanf(in,"%d %d",&r[i].g,&r[i].v);
    sort(r+1,r+n+1,cmp);
    for(i=1;i<=n && gmax>0 ;i++)
    {
        if(r[i].g<=gmax)
        {
            gmax-=r[i].g;
            ct+=r[i].v;
        }
    }
    fprintf(out,"%d",ct);
    return 0;
}