Cod sursa(job #973037)

Utilizator andy1496Casu-Pop Andrei andy1496 Data 13 iulie 2013 10:49:32
Problema Problema rucsacului Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb

#include<stdio.h>

#define maxn 5001
#define maxg 10001
 
using namespace std;
 
int W[5001], P[5001];
int Optim[10001];
 
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 - W[i]; j >= 0; --j) {
            if( Optim[j+W[i]] < Optim[j] + P[i] )
            {
                Optim[j+W[i]] = Optim[j] + P[i];
                if( Optim[j+W[i]] > sol)
                    sol = Optim[j+W[i]];
            }
        }
    printf("%d", sol);
    return 0;
}