Cod sursa(job #1650778)

Utilizator crysstyanIacob Paul Cristian crysstyan Data 11 martie 2016 20:25:03
Problema Problema rucsacului Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include <fstream>
#include <algorithm>
#define NMAX 5005

using namespace std;

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

int i, j, n, G, gr, dp[2][2 * NMAX], pr;

int main()
{
    f >> n >> G;

    for (i = 1; i <= n; ++ i)
    {
        f >> gr >> pr;

        for (j = 0; j <= G; ++ j)
        {
            dp[i % 2][j] = dp[(i + 1) % 2][j];

            if (j - gr >= 0)
                dp[i % 2][j] = max(dp[i % 2][j], dp[(i + 1) % 2][j - gr] + pr);
        }
    }

    g << dp[n % 2][G] << '\n';

    return 0;
}