Cod sursa(job #1022599)

Utilizator Raba_SebastianRaba Sebastian Stefan Raba_Sebastian Data 5 noiembrie 2013 19:36:12
Problema Problema rucsacului Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.67 kb
#include <fstream>
#define NMax 5005
#define GMax 10005
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int N,G,W[NMax],P[NMax],DP[2][GMax],l=1;
void Read()
{
    fin>>N>>G;
    for(int i=1;i<=N;i++)
        {
            fin>>W[i]>>P[i];
        }
}
void Solve()
{
    for(int i=1;i<=N;i++,l=1-l)
    {
            for(int j=1;j<=G;j++)
            {
                DP[l][j]=DP[1-l][j];
                if(j>=W[i])
                    DP[l][j]=max(DP[l][j],DP[1-l][j-W[i]]+P[i]);
            }
    }

}
void Print()
{
    fout<<DP[1-l][G]<<'\n';
}
int main()
{
    Read();
    Solve();
    Print();
    return 0;
}