Cod sursa(job #1902593)

Utilizator zeboftwAlex Mocanu zeboftw Data 4 martie 2017 18:00:56
Problema Problema rucsacului Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include <fstream>
#include <vector>

using namespace std;

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

int w[5005], p[5005];
vector<int> optim;

int main()
{
    int n, G, sol = 0;

    fin >> n >> G;

    for(int i=1; i<=n; i++) fin >> w[i] >> p[i];

    optim.assign(G+1,0);

    for (int i=1; i<=n; i++) {
        for (int j=G-w[i]; j>=0; j--) {
            if (optim[j+w[i]] < optim[j] + p[i]) {
                optim[j+w[i]] = optim[j] + p[i];
                if (sol < optim[j+w[i]]) sol = optim[j+w[i]];
            }
        }
    }

    fout << sol;

    return 0;
}