Pagini recente » Cod sursa (job #301680) | Cod sursa (job #1258373) | Cod sursa (job #2114085) | Cod sursa (job #894720) | Cod sursa (job #2365339)
#include<bits/stdc++.h>
using namespace std;
int n,m;
const int maxN=5000;
const int maxG=10005;
pair<int,int> v[maxN];
int dp[maxG],g;
int main()
{
freopen("rucsac.in","r",stdin);
freopen("rucsac.out","w",stdout);
scanf("%d%d",&n,&g);
for(int i=1;i<=n;i++)
scanf("%d%d",&v[i].first,&v[i].second);
for(int i=1;i<=n;i++)
{
for(int j=g-v[i].first;j>=0;j--)
dp[j+v[i].first]=max(dp[j+v[i].first],dp[j]+v[i].second);
}
int sol=0;
for(int i=0;i<=g;i++)
sol=max(sol,dp[i]);
printf("%d\n",sol);
return 0;
}