Cod sursa(job #2645740)

Utilizator david_octavianoctavian david_octavian Data 29 august 2020 15:30:30
Problema Problema rucsacului Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.61 kb
#include <fstream>
#include <algorithm>
using namespace std;
#define MAXN 5010
#define MAXG 10010
ifstream cin ("rucsac.in");
ofstream cout ("rucsac.out");
int N, G, Pmax;
int W[MAXN], P[MAXN];
int D[2][MAXG];
int main()
{


    cin>>N>>G;
    for(int i = 1; i <= N; ++i)
        cin>>W[i]>>P[i];
    int l=0;
    for(int i = 1; i <= N; ++i, l = 1 - l)
        for(int cw = 0; cw <= G; ++cw)
        {
            D[1-l][cw] = D[l][cw];
            if(W[i] <= cw)
                D[1-l][cw] = max(D[1-l][cw], D[l][cw - W[i]] + P[i]);
        }
    Pmax = D[l][G];
    cout<<Pmax;
    return 0;
}