Cod sursa(job #2051152)

Utilizator PredaBossPreda Andrei PredaBoss Data 28 octombrie 2017 16:40:59
Problema Energii Scor 90
Compilator cpp Status done
Runda Arhiva de probleme Marime 2.39 kb
#include <bits/stdc++.h>

using namespace std;
ifstream fin("energii.in");
ofstream fout("energii.out");
int a[5][10005];
struct energie
{
    int c,p;
};
energie v[1005];
int main()
{
    int g,w,i,j,k,t,s;
    fin>>g>>w;
    t=INT_MAX;
    s=0;
    for(i=1; i<=g; i++)
    {
        fin>>v[i].c>>v[i].p;
        if (v[i].c>=w && v[i].p<t)
        {
            t=v[i].p;
        }
        s=s+v[i].c;
    }
    if(s<w)
    {
        fout<<-1;
    }
    else
    {
        s=0;
        for(i=1; i<=g; i++)
        {
            if(v[i].c<w)
            {
                s=s+v[i].c;
            }
        }
        if(s>=w)
        {
            int f=1;
            k=0;
            s=(w-1)*2;
            while(f<=g)
            {
                for(j=1; j<=s; j++)
                {
                    a[k][j]=a[1-k][j];
                    if(v[f].c<w)
                    {
                        if(a[1-k][j]==0)
                        {
                            if(j==v[f].c)
                            {
                                a[k][j]=v[f].p;
                            }
                            else
                            {
                                if(a[1-k][j-v[f].c]>0)
                                {
                                    a[k][j]=a[1-k][j-v[f].c]+v[f].p;
                                }
                            }
                        }
                        else
                        {
                            if(j==v[f].c)
                            {
                                a[k][j]=min(a[1-k][j],v[f].p);
                            }
                            else
                            {
                                if(a[1-k][j-v[f].c]>0)
                                {
                                    a[k][j]=min(a[1-k][j],a[1-k][j-v[f].c]+v[f].p);
                                }
                            }
                        }
                    }
                }
                if(v[f].c<w)
                {
                    k=1-k;
                }
                f++;
            }
            for(i=w; i<=s; i++)
            {
                if(a[1-k][i]<t && a[1-k][i]>0)
                {
                    t=a[1-k][i];
                }
            }
        }

        fout<<t;
    }
    return 0;
}