Cod sursa(job #2812577)

Utilizator Theo14Ancuta Theodor Theo14 Data 4 decembrie 2021 18:52:07
Problema Energii Scor 0
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.71 kb
#include<fstream>
#include<climits>
using namespace std;

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

long long dp[150002];

struct centrala
{
    int energie,cost;
}v[1002];

int main()
{
    long long i,j,gr,w;
    f>>gr>>w;
    for(i=1;i<=gr;i++)
    {
         f>>v[i].energie>>v[i].cost;
    }
    for(j=1;j<=150;j++)
        dp[j]=1<<30;
    dp[0]=0;
    for(i=1;i<=gr;i++)
    {
        for(j=w;j>=0;j--)
        {
            dp[j+v[i].energie] = min(dp[j+v[i].energie],dp[j]+v[i].cost);
        }
        for(j=w+v[i].energie;j>0;j--)
            dp[j-1]=min(dp[j-1],dp[j]);
    }
    if(dp[w]==(1<<30))
        g<<-1;
    else
        g<<dp[w];
    return 0;
}