Cod sursa(job #1856299)

Utilizator IoanaRocIoana Roceanu IoanaRoc Data 24 ianuarie 2017 19:06:56
Problema Energii Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.76 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("energii.in");
ofstream out("energii.out");
int d[5010];
const int INF=10000010;
int main()
{   int n,w,p[1010],e[1010],i,j,s=0,maxt=0;
    in>>n>>w;
    for(i=1;i<=n;i++){
        in>>e[i]>>p[i];
        s+=e[i];
    }
    if(s<w){
        out<<-1;
        return 0;
    }
    for(i=1;i<=w;i++)
        d[i]=INF;
    d[0]=0;
    for(i=1;i<=n;i++)
        for(j=w-1;j>=0;j--){
            if(d[j]!=INF){
                if(j+e[i]>=w)
                    d[w]=min(d[w],d[j]+p[i]);
                else
                    d[j+e[i]]=min(d[j+e[i]],d[j]+p[i]);
            }
        }
    for(i=1;i<=w;i++)
            cout<<d[i]<<" ";
    out<<d[w];
    return 0;

}