Cod sursa(job #928372)

Utilizator Vally77FMI Calinescu Valentin Gelu Vally77 Data 26 martie 2013 13:44:46
Problema Energii Scor 85
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.71 kb
#include <fstream>
using namespace std;
ifstream ka("energii.in");
ofstream ki("energii.out");
int w[5001],p[5001],d[2][10001],n,g,minim,s;
int maxim(int t,int k)
{
    if(t>=k)
    return t;
    return k;
}
int main()
{
    ka>>n>>g;
    minim=5001;
    for(int i=1;i<=n;i++)
    {ka>>p[i]>>w[i];
    s+=p[i];}
    if(s<g)
    ki<<"-1";
    else
    {
    for(int j=1;j<=n;j++)
    {
        for(int cw=1;cw<=5001;cw++)
        {
            d[1][cw]=d[0][cw];
            if(w[j]<=cw)
            d[1][cw]=maxim(d[1][cw],d[0][cw-w[j]]+p[j]);
            if(d[1][cw]>=g&&cw<minim)
            minim=cw;
        }
        for(int cw=1;cw<=g;cw++)
        {
            d[0][cw]=d[1][cw];
        }
    }
    ki<<minim;
    }
}