Cod sursa(job #1574024)

Utilizator Tomi98Osvath Tamas Tomi98 Data 20 ianuarie 2016 08:32:27
Problema Energii Scor 95
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.67 kb
#include <fstream>
#define D 1003

using namespace std;

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

int sol, e[D], c[D], dp[2][5005], G, W;
int main()
{
    f >> G >> W;
    bool ok = 0;
    sol = 100000000;
    int l = 0;
    for (int i = 1; i <= G; i++)
        f >> e[i] >> c[i];
    for (int i = 1; i <= G; i++){
        l = 1 - l;
    for (int j = 0; j <= 5005; j++){
        dp[1 - l][j] = dp[l][j];
        if (c[i] <= j)
            dp[1 - l][j] = max(dp[l][j], dp[l][j - c[i]] + e[i]);
        if (dp[1 - l][j] >= W && j < sol)
            sol = j;
    }
    }
    if (sol != 100000000) g << sol;
        else g << "-1";

    return 0;
}