Pagini recente » Cod sursa (job #314847) | Cod sursa (job #151779) | Cod sursa (job #274085) | Cod sursa (job #152718) | Cod sursa (job #2672568)
#include <fstream>
using namespace std;
const int nmax = 5000, gmax=10000;
int i, j, n, g, p[nmax], w[nmax], dp[2][gmax];
bool k;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int main()
{
fin >>n >> g;
for(i=1; i<=n; i++)
fin >> w[i] >> p[i];
for(i=1; i<=n; i++) {
for(j=1; j<w[i]; j++)
dp[k][j] = dp[!k][j];
for(j=w[i]; j<=g; j++)
dp[k][j] = max(dp[!k][j], dp[!k][j-w[i]]+p[i]);
k=!k;
}
k=!k;
fout << dp[k][g];
return 0;
}