Cod sursa(job #3340305)

Utilizator daniel_2009Stefan Daniel daniel_2009 Data 13 februarie 2026 17:12:19
Problema Problema rucsacului Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.55 kb
#include <fstream>
#define maxn 5001
#define maxg 10001

using namespace std;

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

int main() {
	ifstream fin("rucsac.in");
	ofstream fout("rucsac.out");
	int N, G;
	fin>>N>>G;

	for(int i = 1; i <= N; ++i) {
		fin>>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]];
			}
		}
	fout<<sol;
	return 0;
}