Cod sursa(job #1521581)

Utilizator mocanasudMocanasu Dragos mocanasud Data 10 noiembrie 2015 17:56:14
Problema Problema rucsacului Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.7 kb
#include<fstream>
using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
inline int max(int a,int b)
{
    if(a>b)
        return a;
    return b;
}
int n,g,p,w,a[2][10010],l;
int main()
{
    in>>n>>g;
    for(int i=1; i<=n; i++)
    {
        in>>w>>p;
        for(int j=1; j<=g; j++)
            if(j<w) // nu incape in j kg
                a[1-l][j]=a[l][j]; // 1-l linia curenta
            else a[1-l][j]=max(a[l][j],a[l][j-w]+p); // l linia anterioara
                // profit j kg cu i-1 obiecte
                // j -greutatea curenta  kg cu i-1 obiecte plus profit curent
        l=1-l;
    }
    out<<a[n][g]<<'\n';
    out.close();
    return 0;

}