Cod sursa(job #2836517)

Utilizator octavian2411Cretu Octavian octavian2411 Data 20 ianuarie 2022 16:00:11
Problema Energii Scor 100
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.8 kb
#include <fstream>

using namespace std;

ifstream in("energii.in");
ofstream out("energii.out");

const int N=1005;
const int G=5005;

int cost[G+1],e[N+1],p[N+1];

int main()
{
    int n, necesar, s=0;
    in>>n>>necesar;
    for (int i=0; i<n; i++)
    {
        in>>e[i]>>p[i];
        s+=e[i];
    }
    for (int j=0; j<=necesar; j++)
    {
        cost[j]=1e8;
    }
    for (int i=0; i<n; i++)
    {
        for (int j=necesar; j>=0; j--)
        {
            if (j<=e[i])
            {
                cost[j]=min(cost[j],p[i]);
            }
            else
            {
                cost[j]=min(cost[j],cost[j-e[i]]+p[i]);
            }
        }

    }
    if (s<necesar)
        out<<-1;
    else
    {
        out<<cost[necesar];
    }
    return 0;
}