Pagini recente » Cod sursa (job #905801) | Borderou de evaluare (job #1924462) | Borderou de evaluare (job #2040772) | Borderou de evaluare (job #176947) | Cod sursa (job #2501405)
#include <fstream>
using namespace std;
ifstream fin ("rucsac.in");
ofstream fout ("rucsac.out");
int n, g, dp[5005][10005], p[5010], w[5010];
int maxim (int a, int b) {
if (a > b)
return a;
else
return b;
}
int main()
{
int i, j, l = 1;
fin >> n >> g;
for (i = 1; i <= n; i++) {
fin >> w[i] >> p[i];
for (j = 1; j <= g; j++) {
if (j - w[i] >= 0)
dp[l][j] = maxim( dp[1-l][j], dp[1-l][ j - w[i] ] + p[i]);
else
dp[l][j] = dp[1-l][j];
}
l = 1-l;
}
fout << dp[1-l][g];
return 0;
}