Cod sursa(job #1428475)

Utilizator Boss4321Andrei Theodore Marginean Boss4321 Data 4 mai 2015 16:50:53
Problema Energii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.9 kb
#include <cstdio>
#include <algorithm>
using namespace std;
const int INF=1e9;
const int WMAX=5001;
int d[WMAX];
int main()
{
    freopen("energii.in","r",stdin);
    freopen("energii.out","w",stdout);
    int G,W,i,e,c,last,j;
    scanf("%d%d",&G,&W);
    last=0;
    for(i=1; i<=W; ++i)
        d[i]=INF;
    for(i=1; i<=G; ++i)
    {
        scanf("%d%d",&e,&c);
        for(j=last; j>=0; --j)
            if(d[j]!=INF)
                if(j+e<=W)
                {
                    if(d[j+e]>d[j]+c)
                    {
                        d[j+e]=d[j]+c;
                        if(j+e>last)
                            last=j+e;
                    }
                }
                else if(d[W]>d[j]+c)
                {
                    d[W]=d[j]+c;
                    last=W;
                }
    }
if(d[W]==INF)
    printf("-1");
else
    printf("%d",d[W]);
}