Cod sursa(job #1054369)

Utilizator lucamateiLuca Matei lucamatei Data 13 decembrie 2013 19:48:33
Problema Energii Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.83 kb
#include <fstream>

using namespace std;
struct nod{int w,c;};
ifstream f("energii.in");
ofstream g("energii.out");
int S,W,n,i,j;int a[5001];
int main()
{f>>n>>W;
nod v[n+1];

for(i=1;i<=n;i++)
    f>>v[i].w>>v[i].c;
   f.close();

    //if (S<W){g<<-1; g.close(); return 0;}
// else
// {
S=0;
a[0]=0;
  for(S=1;S<=W;S++) a[S]=-1;
 for(i=1;i<=n;i++)
{
      for(S=1;S<=W;S++)
        if(a[S]!=-1)
        {if(a[S-v[i].w]!=-1 && S-v[i].w>=0)
            if(a[S-v[i].w]+v[i].c<a[S])
                 a[S]=a[S-v[i].w]+v[i].c;}
            else
                if(a[S-v[i].w]!=-1 && S-v[i].w>=0)
                a[S]=a[S-v[i].w]+v[i].c;

           // g<<v[i].w<<' '<<v[i].c<<'\n';
            //  for(S=1;S<=W;S++)                g<<a[S]<<' ';
            //g<<'\n';
}

   g<<a[W];
   g.close();
   return 0;

}