Cod sursa(job #3220531)

Utilizator CraiuAndreiCraiu Andrei David CraiuAndrei Data 3 aprilie 2024 22:34:53
Problema Problema rucsacului Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.65 kb
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");

int dp[10005][10005], G, n;
int p[10005], g[10005], sol;

int main()
{
	int i, j;
	fin >> n >> G;
	for (i = 1; i <= n; i++)
	{
		fin >> g[i] >> p[i];
		dp[i][g[i]] = p[i];
	}
	for (i = 2; i <= n; i++)
		for (j = 0; j <= G; j++)
		{
			//dp[i][j] = p[j];
			if (g[i] <= j)
				dp[i][j] = max(dp[i - 1][j - g[i]] + p[i], dp[i - 1][j]);
		}
	/*
	for (i = 1; i <= n; i++)
	{
		for (j = 0; j <= G; j++)
			fout << dp[i][j] << " ";
		fout << "\n";
	}
	*/
	sol = dp[n][G];
	fout << sol;
	return 0;
}