Cod sursa(job #3354814)

Utilizator FireWolf15G8david rucareanu FireWolf15G8 Data 20 mai 2026 20:55:08
Problema Problema rucsacului Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.91 kb
#include <iostream>
#include <vector>
#include <queue>
#include <climits>
#include <fstream>

using namespace std;

int max(int a, int b) {
    if (a > b) {
        return a;
    } else {
        return b;
    }
}

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

    int n, g;

    fin >> n >> g;

    vector<pair<int, int>> obj(n+1);

    for (int i = 1; i <= n; i++) {
        int w, p;
        fin >> w >> p;

        obj[i].first = w;
        obj[i].second = p;
    }

    vector<vector<int>> dp(n+1, vector<int>(g+1, 0));

    for (int num = 1; num <= n; num++) {
        auto [cur_w, cur_p] = obj[num];

        for (int w = 1; w <= g; w++) {
            dp[num][w] = dp[num - 1][w];

            if (cur_w <= w) {
                dp[num][w] = max(dp[num][w], dp[num - 1][w - cur_w] + cur_p);
            }
        }
    }

    fout << dp[n][g];

    fin.close();
    fout.close();

    return 0;
}