Cod sursa(job #3354815)

Utilizator FireWolf15G8david rucareanu FireWolf15G8 Data 20 mai 2026 20:57:26
Problema Problema rucsacului Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.87 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<int> w(n+1);
    vector<int> p(n+1);

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

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

    for (int num = 1; num <= n; num++) {
        int cur_w = w[num];
        int cur_p = p[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;
}