Cod sursa(job #1857844)

Utilizator M.AnaAna Marginean M.Ana Data 26 ianuarie 2017 19:18:34
Problema Problema rucsacului Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.56 kb
#include <iostream>
#include <fstream>
#include <algorithm>

using namespace std;

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

int main()
{
	int n, g, w[5010], p[5010];
	in >> n >> g;

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

	int r[5010][10010];

	for (int i = 0; i <= g; ++i)
		r[0][i] = 0;

	for (int i = 1; i <= n; ++i)
	{
		for (int j = 0; j <= g; ++j)
		{
			r[i][j] = r[i - 1][j];

			if (w[i] <= j)
				r[i][j] = max(r[i][j], r[i - 1][j - w[i]] + p[i]);
		}
	}
	
	out << r[n][g];

	return 0;
}