Cod sursa(job #2133403)

Utilizator ionicaion ionica Data 16 februarie 2018 21:34:49
Problema Problema rucsacului Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include <fstream>

using namespace std;
int  a[5001], v[5001], cmax[10001], n, b[10001],gmax;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int main()
{
    int i,j,g,k;
    fin>>n>>gmax;
    for(i=1; i<=n; i++)
            fin>>a[i]>>v[i];

    for(j=1;j<=gmax;j++)
        {
            cmax[j]=-1;
            b[j]=n+1;
        }

    for ( i=1;i<=n;++i)
        for (g=0;g+a[i]<=gmax;g++)
            if(b[g]<i && cmax[g+a[i]]<cmax[g]+v[i])
            {
              cmax[g+a[i]]=cmax[g]+v[i];
              b[g+a[i]]=i;

            }
    int vm=0;
    for(g=1;g<=gmax;g++)
        if(cmax[g]>vm)
        vm=cmax[g];

    fout<<vm;

    return 0;
}