Cod sursa(job #1278282)

Utilizator ovidiuz98Zamfir Ovidiu ovidiuz98 Data 28 noiembrie 2014 17:25:31
Problema Energii Scor 5
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.67 kb
#include <fstream>
#define INF 1000001
using namespace std;
ifstream fin("energii.in");
ofstream fout("energii.out");
int G[1002],W[1002],n,s,i,j,D[5002],minim=INF;
int main(){
    fin>>n>>s;
    for(i=1;i<=n;i++)
        fin>>G[i]>>W[i];
    for(i=1;i<=s;i++)
        D[i]=INF;
    for(i=1;i<=n;i++)
        for(j=0;j<=s;j++)
            if(D[j]!=INF)
                if(D[j]+W[i]<D[j+G[i]]){
                    D[j+G[i]]=D[j]+W[i];
                    if(D[j+G[i]]<minim && j+G[i]>=s)
                        minim=D[j+G[i]];
                }
    if(D[s]==INF)
        fout<<'-1';
    else
        fout<<minim;
    fin.close();fout.close();
    return 0;
}