Cod sursa(job #1548484)

Utilizator TimoteiCopaciu Timotei Timotei Data 10 decembrie 2015 23:08:49
Problema Energii Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.71 kb
#include<fstream>
#define nMax 1001
#define eMax 5001
using namespace std;
int N, eNecesar, C[nMax], E[nMax], dp[nMax][eMax];

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

int main()
{
    f >> N >> eNecesar;
    for(int i = 1; i <= N; i++)
        f >> E[i] >> C[i];
    for(int i = 1; i <= N; i++){
        for(int j = 0; j <= eNecesar; j++)
    {
        if(E[i] > eNecesar) E[i] = eNecesar;


        if(E[i] > j)dp[i][j] = dp[i-1][j];
        else
            if( dp[i][j] != 0) dp[i][j] = min(dp[i][j], dp[i-1][j-E[i]] + C[i]);
        else dp[i][j] = dp[i-1][j-E[i]] + C[i];
        //g << dp[i][j] << " ";
    }
     //g << '\n';
    }
    g << dp[N][eNecesar];

    return 0;
}