Pagini recente » Cod sursa (job #1790160) | Cod sursa (job #1663954) | Cod sursa (job #1706226) | Monitorul de evaluare | Cod sursa (job #1703472)
#include <stdio.h>
#include <stdlib.h>
#define maxim(a, b) ((a > b) ? a : b )
int w[5001], p[5001];
int d[10001];
int main(){
int n, g, i, j;
FILE *fin, *fout;
fin=fopen("rucsac.in", "r");
fout=fopen("rucsac.out", "w");
fscanf(fin, "%d%d", &n, &g);
for(i=1; i<=n; i++){
fscanf(fin, "%d%d", &w[i], &p[i]);
for(j=g; j>=w[i]; j--)
d[j]=maxim(d[j], d[j-w[i]] + p[i]);
}
fprintf(fout, "%d", d[g]);
fclose(fin);
fclose(fout);
return 0;
}