Cod sursa(job #2921976)

Utilizator BeilandArnoldArnold Beiland BeilandArnold Data 2 septembrie 2022 18:19:50
Problema Problema rucsacului Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.76 kb
#include <fstream>
#include <vector>
#include <algorithm>
using namespace std;

int main()
{
    ifstream in("rucsac.in");
    ofstream out("rucsac.out");

    int n, g;
    in >> n >> g;

    vector<int> w(n), p(n);
    for (int i = 0; i < n; ++i)
        in >> w[i] >> p[i];

    vector<int> d(g+1, 0); // max profit for each weight using objects up to 
                           // the last one considered
    
    for (int i = 0; i < n; ++i) {
        vector<int> d_new(g+1);

        for (int ig = 0; ig <= g; ++ig) {
            if (ig < w[i])
                d_new[ig] = d[ig];
            else
                d_new[ig] = max(d[ig], d[ig-w[i]] + p[i]);
        }

        d.swap(d_new);
    }

    out << d[g] << '\n';

    return 0;
}