Cod sursa(job #2203402)

Utilizator berindeiChesa Matei berindei Data 12 mai 2018 11:08:35
Problema Problema rucsacului Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.51 kb
#include <bits/stdc++.h>
using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
int const DIM = 1e4+100;

int dp[DIM];

int main(){
    int n, G, c, val, mmax, i, j;
    in >> n >> G;
    for (auto &x: dp) x=-1;
    dp[0]=0;
    for (i=1; i<=n; i++){
        in >> c >> val;
        for (j=G; j>=0; j--)
            if (j+c<=G && dp[j]!=-1 && dp[j+c]<dp[j]+val) dp[j+c] = dp[j]+val;
    }
    mmax=-1;
    for (i=0; i<=G; i++)
        mmax=max(mmax, dp[i]);
    out << mmax;
}