Cod sursa(job #1856062)

Utilizator theo.stoicanTheodor Stoican theo.stoican Data 24 ianuarie 2017 14:48:35
Problema Problema rucsacului Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.9 kb

// Infoarena - Arhiva Educationala rucsac
// Februrie 2012 Marius Dumitran
// Programare dinamica clasica timp O(N*G) memorie O(G)

#include<string.h>
#include<stdio.h>
#include<vector>
#include<algorithm>
#define maxn 5001
#define maxg 10001

using namespace std;

int W[maxn], P[maxn];
int Optim[maxg];

int main() {

    freopen("rucsac.in", "r", stdin);
    freopen("rucsac.out", "w", stdout);
    int N, G;
    scanf("%d %d", &N, &G);

    for (int i = 1; i <= N; ++i) {
        scanf("%d %d", &W[i], &P[i]);
    }

    Optim[0] = 0;
    int sol = 0;

    for( int i = 1; i <= N; ++i)
        for( int j = G; j >= W[i]; --j) {
            if( Optim[j] < Optim[j-W[i]] + P[i] )
            {
                Optim[j] = Optim[j-W[i]] + P[i];
                if( Optim[j] > sol)
                    sol = Optim[j];
            }
        }
    printf("%d", sol);
    return 0;
}