Cod sursa(job #2394178)
Utilizator | Bogdan Ivancu Bogauuu | Data | 1 aprilie 2019 13:05:46 |
---|---|---|---|
Problema | Problema rucsacului | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.58 kb |
#include <fstream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int n,gm,i,j,maxim,g[5005],p[5005],d[10005];
int main()
{
fin >> n >> gm;
for (i=1;i<=n;i++)
{
fin >> g[i] >> p[i];
d[i]=-1;
}
for (i=i;i<=gm;i++) d[i]=-1;
d[0]=0;
for (i=1;i<=n;i++)
{
for (j=gm;j>=0;j--)
{
if (d[j]!=-1 && j+g[i]<=gm) d[j+g[i]]=max(d[j+g[i]],d[j]+p[i]);
}
}
maxim=-1;
for (i=1;i<=gm;i++) if (d[i]>maxim) maxim=d[i];
fout << maxim;
return 0;
}