Cod sursa(job #2344780)

Utilizator LittleWhoFeraru Mihail LittleWho Data 15 februarie 2019 16:59:20
Problema Problema rucsacului Scor 65
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.56 kb
#include <bits/stdc++.h>

using namespace std;

const int nmax = 5000;

typedef unsigned int uint; 
uint n, G, W[nmax], P[nmax];
uint dp[nmax];
uint sol;

int main() {
  freopen("rucsac.in", "r", stdin);
  freopen("rucsac.out", "w", stdout);

  cin >> n >> G;
  for (int i = 0; i < n; i++) {
    cin >> W[i] >> P[i];
  }

  for (int i = 0; i < n; i++) {
    for (int j = G - W[i]; j >= 0; j--) {
      dp[j + W[i]] = max(
            dp[j + W[i]],
            dp[j] + P[i]
          );
      sol = max(sol, dp[j + W[i]]);
    }
  }

  cout << sol << "\n";

  return 0;
}