Cod sursa(job #1893230)

Utilizator stefii_predaStefania Preda stefii_preda Data 25 februarie 2017 15:56:18
Problema Problema rucsacului Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include <fstream>

using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
const int N = 5005;
const int GMAX = 10005;
int g[N], p[N];
int best[GMAX];

int main()
{
    int n, G, i, j;
    in >> n >> G;
    for(i = 1; i <= n; i++)
        in >> g[i] >> p[i];
    for(i = 1; i <= G; i++)
        best[i] = -1;
    best[0] = 0;
    for(i = 1; i <= n; i++)
        for(j = G - g[i]; j >= 0; j--)
            if(best[j] != -1 && best[j + g[i]] < best[j] + p[i])
                best[j + g[i]] = best[j] + p[i];
    int maxim = 0;
    for(i = 1; i <= G; i++)
        if(best[i] > maxim)
            maxim = best[i];
    out << maxim;
    return 0;
}