Pagini recente » Cod sursa (job #319368) | Cod sursa (job #539907) | Cod sursa (job #659901) | Cod sursa (job #1069400) | Cod sursa (job #2449163)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int n, g, dp[2][10005], w, p, L;
int main()
{
fin >> n >> g;
L = 1;
for(int i = 1; i <= n; ++i, L = 1 - L)
{
fin >> w >> p;
for(int j = 0; j <= g; ++j)
{
dp[L][j] = dp[1 - L][j];
if(j >= w)
dp[L][j] = max(dp[L][j], dp[1 - L][j - w] + p);
}
}
int sol = 0;
L = 1 - L;
for(int i = 1; i <= g; ++i)
sol = max(sol, dp[L][i]);
fout << sol;
return 0;
}