Pagini recente » Cod sursa (job #415490) | Cod sursa (job #1544043) | Cod sursa (job #2334931) | Cod sursa (job #205047) | Cod sursa (job #2685384)
#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;
}