Cod sursa(job #2286342)
Utilizator | Data | 20 noiembrie 2018 10:18:56 | |
---|---|---|---|
Problema | Problema rucsacului | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.52 kb |
#include <bits/stdc++.h>
#define NMAX 5010
#define GMAX 10010
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int n,gmax;
int c[NMAX],g[NMAX];
int cmax[GMAX];
void citire();
void pd();
int main()
{citire();
pd();
fout<<cmax[gmax]<<'\n';
return 0;
}
void citire()
{int i;
fin>>n>>gmax;
for(i=1;i<=n;i++)
fin>>g[i]>>c[i];
}
void pd()
{int i,x;
for(i=1;i<=n;i++)
for(x=gmax;x>=1;x--)
if(x-g[i]>=0)
cmax[x]=max(c[i]+cmax[x-g[i]],cmax[x]);
}