Cod sursa(job #2135785)
Utilizator | Andrei Andriescu andreiandriescu | Data | 19 februarie 2018 11:01:47 |
---|---|---|---|
Problema | Problema rucsacului | Scor | 10 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.51 kb |
#include <fstream>
#include <iostream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int a[5001],v[5001],i,g,gprim,vmax[5001][10001],n,gmax;
int main()
{
fin>>n>>gmax;
for(i=1; i<=n; i++)
fin>>a[i]>>v[i];
for(i=1; i<=n; i++)
for(g=1; g<=gmax; g++)
{
vmax[i][g]=vmax[i-1][g];
if(a[i]<=g && v[i]+vmax[i-1][g-a[i]]>vmax[i][g])
vmax[i][g]=v[i]+vmax[i-1][g-a[i]];
}
fout<<vmax[n][gmax];
}