Cod sursa(job #1736253)

Utilizator delia_ioanaCeapa Delia Ioana delia_ioana Data 1 august 2016 14:40:22
Problema Problema rucsacului Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include <fstream>
#include <iostream>
#include <vector>
 
using namespace std;
 
int main() {
	vector<int> W, P;
	ifstream infile; 
   	infile.open("rucsac.in");
	ofstream outfile;
	outfile.open("rucsac.out");

	int N, G, max = 0, val1, val2;
	infile >> N >> G;

	vector<int> Din(G + 1, 0);
     
	for (int i = 0; i < N; i ++) {
		infile >> val1 >> val2;
		W.push_back(val1);
		P.push_back(val2);
	}

	for (int i = 0; i <= G; i ++)
		for (int j = 0; j < N; j ++)
			if (i + W[j] <= G && Din[i + W[j]] < Din[i] + P[j])
				Din[i + W[j]] = Din[i] + P[j];
	
	for (int i = 0; i <= G; i ++)
		if (Din[i] > max)
			max = Din[i];     
	
	outfile << max << endl;
	return 0;
}