Cod sursa(job #2932138)

Utilizator divadddDavid Curca divaddd Data 1 noiembrie 2022 22:57:53
Problema Problema rucsacului Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.63 kb
#include <iostream>
#include <cstring>
#include <fstream>
#define MAX 10002
using namespace std;
int n,g,w,p,dp[MAX],ans;

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

int main()
{
    fin >> n >> g;
    memset(dp, -1, sizeof(dp));
    dp[0] = 0;
    for(int i = 1; i <= n; i++){
        fin >> w >> p;
        for(int j = g-w; j >= 0; j--){
            if(dp[j] != -1){
                if(dp[j+w] <= dp[j]+p){
                    dp[j+w] = dp[j]+p;
                }
            }
        }
    }
    for(int i = 1; i <= g; i++){
        ans = max(ans, dp[i]);
    }
    fout << ans;
    return 0;
}