Pagini recente » Cod sursa (job #471843) | Cod sursa (job #38145) | Cod sursa (job #2521982) | Cod sursa (job #451871) | Cod sursa (job #2272249)
#include <bits/stdc++.h>
using namespace std;
const int GMAX=5e7+2;
bool A[GMAX];
struct obiect
{
int G, P;
};
int N, G, i, W, P, j;
int sol[GMAX], ans, s;
int main()
{
freopen("rucsac.in", "r", stdin);
freopen("rucsac.out", "w", stdout);
scanf("%d%d", &N, &G);
A[0]=1;
for(i=1; i<=N; i++)
{
scanf("%d%d", &W, &P);
for(j=G-W; j>=0; j--)
if(A[j])
{
A[j+W]=true;
sol[j+W]=max(sol[j+W], (sol[j]+P));
}
s+=W;
}
for(i=G; i>=0; i--)
ans=max(ans, sol[i]);
printf("%d\n", ans);
return 0;
}