Cod sursa(job #2602641)

Utilizator Alex_tz307Lorintz Alexandru Alex_tz307 Data 17 aprilie 2020 15:45:07
Problema Problema rucsacului Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.6 kb
#include <bits/stdc++.h>

#define maxn 5001
#define maxg 10001

using namespace std;

ifstream f ("rucsac.in");
ofstream g ("rucsac.out");

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

int main()
{
	int N, G;
	f >> N >> G;
	for (int i = 1; i <= N; ++i) f >> 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]];
    }
	g << sol;

	f.close();
	g.close();
	return 0;
}