Mai intai trebuie sa te autentifici.

Cod sursa(job #1036509)

Utilizator vladcfVlad Frasineanu vladcf Data 19 noiembrie 2013 13:58:36
Problema Energii Scor 5
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.24 kb
#include <fstream>
#include <algorithm>
using namespace std;

int n,gr,w[5001],p[5001],i,v[2][10000001],j,k,s,t,i1;
int main()
{
    ifstream f("energii.in");
    ofstream g("energii.out");

    f>>n>>gr;
    s=0;
    for (i=0;i<n;i++)
        {
            f>>w[i]>>p[i];
            s=s+w[i];
        }
    if (s>=gr)
    {
    k=1;
    for (i=0;i<n;i++)
        {
            k=1-k;
            for (i1=1;i1<s;i1++)
                {
                    v[1-k][i1]=v[k][i1];
                    if (v[1-k][i1]!=0)
                                {
                                    if (w[i]<=i1) v[1-k][i1]=min(v[k][i1],v[k][i1-w[i]]+p[i]);
                                }
                                else
                                {
                                    if (w[i]==i1) v[1-k][i1]=v[k][i1-w[i]]+p[i];
                                    if (w[i]<i1)
                                    {
                                        if (v[k][i1-w[i]]!=0) v[1-k][i1]=v[k][i1-w[i]]+p[i];
                                    }
                                }

                }
        }
    t=0;
    while (t<gr || v[1-k][t]==0) t++;
    g<<v[1-k][t];
    }
    else
    {
    g<<"-1";
    }
    f.close();
    g.close();
    return 0;
}