Pagini recente » Cod sursa (job #1393992) | Cod sursa (job #2572799) | Cod sursa (job #2212128) | Cod sursa (job #1664678) | Cod sursa (job #1006680)
#include <fstream>
using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
const int NMAX = 10002;
int valueFormed[NMAX];
int main()
{
int N,G, weight, value, partialWeight, maxWeight = 0;
in >> N >> G;
valueFormed[0] = 1;
for(int i = 0; i < N; i++){
in >> weight >> value;
for(partialWeight = maxWeight; partialWeight >= 0; partialWeight--){
if(partialWeight + weight <= G && valueFormed[partialWeight]){
valueFormed[partialWeight + weight] = max(valueFormed[partialWeight + weight], valueFormed[partialWeight] + value);
}
}
maxWeight += weight;
maxWeight = min(maxWeight, G);
}
//144409
out << valueFormed[maxWeight] -1 << '\n';
return 0;
}