Cod sursa(job #614148)

Utilizator CBogdanCiobanu Bogdan CBogdan Data 5 octombrie 2011 19:04:24
Problema Problema rucsacului Scor 80
Compilator cpp Status done
Runda Arhiva educationala Marime 0.5 kb
#include<cstdio>
#include<algorithm>
using namespace std;

int N,G,i,cw,l,sol,W[5010],P[5010],D[2][10010];

//void read(),solve();

int main()
{
	freopen("rucsac.in","r",stdin);
	freopen("rucsac.out","w",stdout);
	scanf("%d%d",&N,&G);
	for(i=1;i<=N;i++)scanf("%d%d",&W[i],&P[i]);
	for(i=1;i<=N;i++,l=1-l)
	{
		for(cw=0;cw<=G;cw++)
		{
			D[1-l][cw]=D[l][cw];
			if(W[i]<=cw)
				D[1-l][cw]=max(D[l][cw],D[l][cw-W[i]]+P[i]);
		}
	}
	sol=D[l][G];
	printf("%d\n",sol);
	
	return 0;
}