Pagini recente » Cod sursa (job #2010027) | Cod sursa (job #1640299) | Cod sursa (job #1566672) | Cod sursa (job #2066546) | Cod sursa (job #1533664)
#include <iostream>
#include <fstream>
using namespace std;
const int Nmax = 5005;
const int Gmax = 10005;
int N, G;
int wg[Nmax], pr[Nmax];
int M[5][Gmax];
void read()
{
ifstream f("rucsac.in");
f >> N >> G;
for(int i = 1; i <= N; i ++)
{
f >> wg[i] >> pr[i];
}
f.close();
}
void Backpack()
{
for(int i = 1; i <= N; i ++)
{
for(int j = 1; j <= G; j ++)
{
M[1][j] = M[2][j];
}
for(int j = 1; j <= G; j ++)
{
M[2][j] = M[1][j];
if(wg[i] <= j)
{
M[2][j] = max(M[1][j], M[1][j-wg[i]]+pr[i]);
}
}
}
}
void print()
{
ofstream g("rucsac.out");
g << M[2][G];
g.close();
}
int main()
{
read();
Backpack();
print();
return 0;
}