Cod sursa(job #1768098)
Utilizator | Data | 30 septembrie 2016 10:42:45 | |
---|---|---|---|
Problema | Problema rucsacului | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.51 kb |
#include<cstdio>
int v[10001];
int main(){
int n,g,w,p,i,j,max;
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,&p);
for(j=g-w;j>=1;j--)
if(v[j]!=0)
if(v[j+w]<v[j]+p)
v[j+w]=v[j]+p;
if(v[w]<p)
v[w]=p;
}
max=0;
for(i=1;i<=g;i++)
if(v[i]>max)
max=v[i];
printf("%d",max);
return 0;
}