Cod sursa(job #667040)

Utilizator vlad2901Vlad Berindei vlad2901 Data 22 ianuarie 2012 16:01:03
Problema Energii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.86 kb
#include <cstdio>
#include <algorithm>

#define GMAX 1001
#define WMAX 5001
#define CMAX 1000000000

using namespace std;

int a[2][WMAX], G, W;
int c[GMAX], e[GMAX];

int main()
{
    int i, j, cap, l;

    freopen("energii.in", "r", stdin);
    freopen("energii.out", "w", stdout);

    scanf("%d %d", &G, &W);


    for(i=1;i<=G;++i)
    {
        scanf("%d %d", &e[i], &c[i]);
    }

    for(i=1;i<=W;++i)
    {
        a[0][i] = CMAX;
    }

    for(i=1,l=1;i<=G;++i,l=1-l)
    {
        for(j=0;j<=W;++j)
        {
            if(e[i] <= j)
            {
                a[l][j] = min(a[1-l][j], a[1-l][j - e[i]] + c[i]);
            }
            if(e[i] >= j)
            {
                a[l][j] = min(a[1-l][j], c[i]);
            }
        }
    }

    printf("%d", a[1-l][W] >= CMAX ? -1 : a[1-l][W]);

    return 0;
}