Pagini recente » Cod sursa (job #2082407) | Cod sursa (job #3139296) | Cod sursa (job #2295349) | Cod sursa (job #1513513) | Cod sursa (job #1632416)
#include <iostream>
#include <fstream>
std::ifstream fin("rucsac.in");
std::ofstream fout("rucsac.out");
int v[2][10003];
int n, totalWeight;
int currentValue, currentWeight;
int reinit()
{
for (int i = 0; i <= totalWeight; i++)
v[0][i] = v[1][i];
}
int maxValue(int a, int b)
{
if(a >= b)
return a;
else
return b;
}
int main(int argc, char *argv[])
{
fin >> n >> totalWeight;
for (int i = 0; i <= totalWeight; i++)
v[0][i] = 0;
v[1][0] = 0;
for (int contor = 1; contor <= n; contor++)
{
fin >> currentWeight >> currentValue;
for (int i = 1; i <= totalWeight; i++)
{
if (i < currentWeight)
v[1][i] = v[0][i];
else
v[1][i] = maxValue(v[0][i], currentValue + v[0][i - currentWeight]);
}
reinit();
}
fout << v[0][totalWeight];
return 0;
}