Cod sursa(job #2685384)

Utilizator Florian11232Florian Susai Florian11232 Data 16 decembrie 2020 19:11:55
Problema Problema rucsacului Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.66 kb
#include <iostream>
#include <fstream>
#include<vector>
#include<algorithm>
#define maxn 5001
#define maxg 10001
 
using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
int W[maxn], P[maxn];
int Optim[maxg];
 
int main() {
	
	
	int N, G;
	in>>N>>G;
	
	for (int i = 1; i <= N; ++i) {
		in>>W[i]>>P[i];
	}
	
	Optim[0] = 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];
			}
		}

    // for (i = 0; i <= G; i++) {
    //     cout << Optim[i] << " ";
    // }
    // cout << '\n';
	out<<Optim[G]<<"\n";
	return 0;
}