Pagini recente » Cod sursa (job #2168984) | Cod sursa (job #1984912) | Istoria paginii utilizator/cristina-ramona | Rating Claudiu Comorasu (Tairen) | Cod sursa (job #2398568)
#include <fstream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int main()
{
int n, g, *v, w, p;
fin >> n >> g;
v = new int[g + 1];
for (int i = 0; i <= g; ++i) {
v[i] = -1;
}
v[0] = 0;
while (n--) {
fin >> w >> p;
for (int j = 0, sj = g - w, u = -1; j <= sj; ++j) {
if (v[j] != -1 && u != j) {
if (v[j + w] < v[j] + p) {
v[j + w] = v[j] + p;
u = j + w;
}
}
}
}
for (int i = 0; i <= g; ++i) {
if (v[i] > n) {
n = v[i];
}
}
fout << n;
}