Cod sursa(job #944095)

Utilizator alexandru70Ungurianu Alexandru alexandru70 Data 27 aprilie 2013 12:59:12
Problema Problema rucsacului Scor 35
Compilator cpp Status done
Runda Arhiva educationala Marime 0.47 kb
#include <fstream>
using namespace std;
ifstream in ("rucsac.in");
ofstream out ("rucsac.out");

short n,g;
int dp[5001][10001], p[5001], w[5001];

inline int max(int a, int b)
{
	if(a>b)return a;
	return b;
}
int main()
{
	in >> n >> g;
	for(short i = 1; i <= n; i++)
		in >> w[i] >> p[i];
	for(short i = 1; i <= n; i++)
		for(short j = 0; j <= g; j++)
		{
			if(j >=w[i])
				dp[i][j]=max(dp[i-1][j],dp[i-1][j-w[i]]+p[i]);
			else
				dp[i][j]=dp[i-1][j];
		}
	out << dp[n][g];
}