Cod sursa(job #2437019)

Utilizator blotucosmincosmin blotucosmin Data 8 iulie 2019 08:37:43
Problema Problema rucsacului Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.89 kb
#include <fstream>
using namespace std;
int dp[5001][10001], g[5001], c[5001];
int G, n, i, j, sol;
int main()
{
    ifstream fin("rucsac.in");
    ofstream fout("rucsac.out");
    fin >> n >> G;
    for(i = 1; i <= n; i ++)
     fin >> g[i] >> c[i];
       // Dinamica dp[i][j] - profitul maxim pe care-l putem obtine adaugand o submultime a
       // primelor i obiecte, insumand greutatea j
    for(i = 1; i <= n; i ++)
        for(j = 0; j <= G; j ++)
        {
            // Mai intai nu punem obiectul i.
            dp[i][j] = dp[i - 1][j];
            // Daca acest lucru duce la o solutie curenta mai buna, adaugam obiectul i la o
            // solutie anterioara.
            if(g[i] <= j)
                dp[i][j] = max(dp[i][j], dp[i - 1][j - g[i]] + c[i]);
        }
    // Solutia se va afla in statea dp[n][G]
   sol = dp[n][G];
   fout << sol;
   return 0;
}