Cod sursa(job #2299834)

Utilizator RaresLiscanLiscan Rares RaresLiscan Data 10 decembrie 2018 11:25:10
Problema Problema rucsacului Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.69 kb
#include <bits/stdc++.h>

using namespace std;

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

int dp[5005][10005];
vector <pair <int, int> > V;

int main()
{
    int n, g;
    fin >> n >> g;
    V.push_back(pair <int, int> (0, 0));
    for (int i = 1; i <= n; i ++) {
        int a, b;
        fin >> a >> b;
        V.push_back(pair <int, int> (a, b));
        dp[i][a] = b;
    }
    for (int i = 1; i <= n; i ++) {
        for (int j = 1; j <= g; j ++) {
            if (j - V[i].first < 0) dp[i][j] = dp[i - 1][j];
            else dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - V[i].first] + V[i].second);
        }
    }
    fout << dp[n][g];
    return 0;
}