Cod sursa(job #2482787)

Utilizator ovidiu_boambaOvidiu Boamba ovidiu_boamba Data 28 octombrie 2019 21:05:02
Problema Problema rucsacului Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.12 kb
#include <fstream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int v1[10005],v2[10005],gmax,n,gr[10005],pr[10005];
int main()
{
    int i,g;
    fin>>n>>gmax;
    for(i=1; i<=n; i++)
        fin>>gr[i]>>pr[i];
    for(i=1; i<=n; i++)
    {
        if(i%2==1)
        {
            for(g=1; g<=gmax; g++)
            {
                if(g>=gr[i])
                {
                    if(v2[g-gr[i]]+pr[i]>v2[g])
                        v1[g]=v2[g-gr[i]]+pr[i];
                    else
                        v1[g]=v2[g];
                }
                else v1[g]=v2[g];
            }
        }
        else
        {
            for(g=1; g<=gmax; g++)
            {
                if(g>=gr[i])
                {
                    if(v1[g-gr[i]]+pr[i]>v1[g])
                        v2[g]=v1[g-gr[i]]+pr[i];
                    else
                        v2[g]=v1[g];
                }
                else v2[g]=v1[g];
            }
        }
    }
    if(n%2==0) fout<<v2[gmax];
    else fout<<v1[gmax];
    fin.close();
    fout.close();
    return 0;
}