Cod sursa(job #1449773)

Utilizator gheorghehagiGheorghe Hagi gheorghehagi Data 10 iunie 2015 16:15:16
Problema Energii Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.72 kb
#include<cstdio>
struct generator{int e, c;};
generator v[1001];
int cost[15001];
int main(){
    int i,n,w,g,j,max;
    freopen("energii.in","r",stdin);
    freopen("energii.out","w",stdout);
    scanf("%d%d",&g,&w);
    max=0;
    for(i=1;i<=g;i++){
        scanf("%d %d",&v[i].e,&v[i].c);
        if(v[i].e>max)
            max=v[i].e;
    }
    n=w+max;
    for(i=1;i<=n;i++){
        for(j=n;j>=1;j--)
            if(cost[j]!=0)
                if(j+v[i].e<=n)
                    if(cost[j]+v[i].c<cost[j+v[i].e])
                        cost[j+v[i].e]=cost[j]+v[i].c;
        cost[v[i].e]=v[i].c;
    }
    i=w;
    while(cost[i]==0&&i<=n)
        i++;
    printf("%d",cost[i]);
    return 0;
    }