Pagini recente » Cod sursa (job #1632489) | Cod sursa (job #15184) | Cod sursa (job #2703892) | Cod sursa (job #1924714) | Cod sursa (job #3220531)
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int dp[10005][10005], G, n;
int p[10005], g[10005], sol;
int main()
{
int i, j;
fin >> n >> G;
for (i = 1; i <= n; i++)
{
fin >> g[i] >> p[i];
dp[i][g[i]] = p[i];
}
for (i = 2; i <= n; i++)
for (j = 0; j <= G; j++)
{
//dp[i][j] = p[j];
if (g[i] <= j)
dp[i][j] = max(dp[i - 1][j - g[i]] + p[i], dp[i - 1][j]);
}
/*
for (i = 1; i <= n; i++)
{
for (j = 0; j <= G; j++)
fout << dp[i][j] << " ";
fout << "\n";
}
*/
sol = dp[n][G];
fout << sol;
return 0;
}