Cod sursa(job #1274941)

Utilizator Corina1997Todoran Ana-Corina Corina1997 Data 24 noiembrie 2014 16:38:49
Problema Problema rucsacului Scor 65
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include <fstream>
using namespace std;

#define MAXN 10000
#define MAXG 10000

ifstream is("rucsac.in");
ofstream os("rucsac.out");

int c[2][MAXG];
int lp, lc = 1;
int n, S, g[MAXG], v[MAXN];

int main()
{
    is >> n >> S;
    for ( int i = 1; i <= n; i++ )
        is >> g[i] >> v[i];
    for( int i = 1; i <= n; ++i, lc = !lc, lp =! lp )
    {
        for( int j = 1; j <= S; ++j )
        {
            c[lc][j] = c[lp][j];
            if( j >= g[i] && c[lc][j] < c[lp][j-g[i]] + v[i] )
                c[lc][j] = c[lp][j-g[i]] + v[i];
        }
    }
    os << c[lp][S];
    is.close();
    os.close();
    return 0;
}