Cod sursa(job #819381)

Utilizator 2dorTudor Ciurca 2dor Data 18 noiembrie 2012 21:23:48
Problema Problema rucsacului Scor 35
Compilator cpp Status done
Runda Arhiva educationala Marime 0.59 kb
#include <fstream>
#include <iostream>
using namespace std;

ifstream fin("rucsac.in");
ofstream fout("rucsac.out");

int i, aw, n, g, M[5005][10005], W[5005], P[5005];

int main() {
    fin >> n >> g;
    for (i = 1; i <= n; ++i)
        fin >> W[i] >> P[i];
    fin.close();
    for (i = 1; i <= n; ++i) {
        for (aw = 0; aw <= g; ++aw) {
            if (W[i] <= aw)
                M[i][aw] = max(M[i - 1][aw - W[i]] + P[i], M[i - 1][aw]);
            else
                M[i][aw] = M[i - 1][aw];
        }
    }
    fout << M[n][g];
    fout.close();
    return 0;
}