Pagini recente » Cod sursa (job #900884) | Cod sursa (job #2705317) | Cod sursa (job #2527225) | Cod sursa (job #2876035) | Cod sursa (job #2505954)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int N, G, k = 1;
int p[10001], g[10001], dp[2][10001];
int main()
{
fin >> N >> G;
for(int i = 1; i <= N; i++)
{
fin >> g[i] >> p[i];
}
for(int i = 1; i <= N; i++)
{
for(int j = 1; j <= G; j++)
{
if(j - g[i] >= 0)
{
dp[k][j] = max(dp[1-k][j], dp[1-k][j - g[i]] + p[i]);
}
else
{
dp[k][j] = dp[1-k][j];
}
}
k = 1 - k;
}
fout << dp[1-k][G];
return 0;
}