Cod sursa(job #1857857)

Utilizator M.AnaAna Marginean M.Ana Data 26 ianuarie 2017 19:31:56
Problema Energii Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.54 kb
#include <iostream>
#include <fstream>
#include <algorithm>

using namespace std;

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

int n, g, w[5010], p[5010];
int r[2][10010];

int main()
{

	in >> n >> g;

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

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

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

	return 0;
}