Pagini recente » Cod sursa (job #1223519) | Cod sursa (job #2249700) | Cod sursa (job #2260829) | Cod sursa (job #2823807) | Cod sursa (job #1804207)
#include <cstdio>
#include <algorithm>
using namespace std;
const int G=10005;
int n,g,w,p,maxx,d[G];
int main()
{
freopen("rucsac.in","r",stdin);
freopen("rucsac.out","w",stdout);
scanf("%d%d",&n,&g);
for(int k=1;k<=n;k++){
scanf("%d%d",&w,&p);
if(w>g or p==0) continue;
for(int j=min(maxx, g-w);j>=0;j--){
if(d[j+w]<d[j]+p){
d[j+w]=d[j]+p;
if(j+w>maxx) maxx=j+w;
}
}
}
maxx=0;
for(int i=g;i>=0;i--)
if(d[i]>maxx) maxx=d[i];
printf("%d\n",maxx);
return 0;
}