Pagini recente » Cod sursa (job #1085057) | Cod sursa (job #521341) | Cod sursa (job #3199570) | Cod sursa (job #678607) | Cod sursa (job #3289660)
#include <iostream>
#include <fstream>
#include <vector>
#include <cmath>
using namespace std;
int main() {
ifstream fin("rucsac.in");
int N, G;
fin >> N >> G;
vector<pair<int, int>> objects(N);
for (int i = 0; i < N; i++) {
fin >> objects[i].first;
fin >> objects[i].second;
}
fin.close();
vector<int> targets(G + 1, 0);
for (int i = 0; i < N; i++) {
for (int j = G; j >= 0; j--) {
if (j - objects[i].first >= 0)
targets[j] = max(targets[j], objects[i].second + targets[j - objects[i].first]);
}
}
int maximum = 0;
for (int i = 0; i <= G; i++)
maximum = max(maximum, targets[i]);
ofstream fout("rucsac.out");
fout << maximum;
fout.close();
return 0;
}