Cod sursa(job #1200934)

Utilizator BogdanisarBurcea Bogdan Madalin Bogdanisar Data 23 iunie 2014 21:38:50
Problema Energii Scor 5
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.01 kb
#include<iostream>
#include<fstream>
using namespace std;
ifstream f("energii.in");
ofstream g("energii.out");
int N,W,i,j,t;
int e[1002],c[1002];
int a[2][5002];

int main()
{
    f>>N>>W;
    for (i=1;i<=N;i++)
        {f>>e[i]>>c[i];t+=e[i];}
    if (t<W)
        g<<-1;
    else
    {
        for (i=0;i<2;i++)
        {
            for (j=1;j<=W;j++)
            {
                a[i][j]=350000;
            }
        }
        for (i=1;i<=N;i++)
        {
            for (j=1;j<=W;j++)
            {
                if (e[i]>=j)
                    a[1][j]=min(a[0][j],c[i]);
                else
                    a[1][j]=min(a[0][j],a[0][j-e[i]]+c[i]);
            }
        }
        for (j=0;j<=W;j++)
            a[0][j]=a[1][j];
        /*for (i=1;i<=N;i++)
        {
            for (j=1;j<=W;j++)
            {
                cout<<a[i][j]<<' ';
            }
            cout<<'\n';
        }*/
        g<<a[1][W]<<'\n';
    }
    f.close();g.close();
    return 0;
}