Pagini recente » Cod sursa (job #995197) | Cod sursa (job #1887206) | Cod sursa (job #1698042) | Cod sursa (job #3126898) | Cod sursa (job #614145)
Cod sursa(job #614145)
#include<cstdio>
#include<algorithm>
using namespace std;
int N,G,i,cw,l,W[5010],P[5010],D[3][10010];
void read(),solve();
int main()
{
read();
solve();
return 0;
}
void read()
{
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]);
}
void solve()
{
for(i=1;i<=N;i++,l=1-l)
{
for(cw=1;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]);
}
}
printf("%d\n",D[l][G]);
}