Cod sursa(job #2910388)

Utilizator Luca_Miscocilucainfoarena Luca_Miscoci Data 20 iunie 2022 13:37:39
Problema Problema rucsacului Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.55 kb
#include <fstream>

using namespace std;

#define NMAX 10000
int d[NMAX + 1], dp[NMAX + 1];

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

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

    for(int j = 0; j <= g; j++){
      d[j] = dp[j];
      if(j >= w)
        d[j] = max(d[j], dp[j - w] + p);
      }
    for(int j = 0; j <= g; j++)
      dp[j] = d[j];
  }
  for(int i = 0; i <= g; i++)
    ans = max(ans, dp[i]);
  fout << ans << '\n';
  return 0;
}