Pagini recente » Cod sursa (job #2874402) | Cod sursa (job #287410) | Cod sursa (job #2244878) | Cod sursa (job #1438938) | Cod sursa (job #840926)
Cod sursa(job #840926)
#include <fstream>
using namespace std;
const char iname[] = "rucsac.in";
const char oname[] = "rucsac.out";
ifstream fin(iname);
ofstream fout(oname);
int N , Gmax , i , j , gc , ind_aux;
int G[ 5004 ] , P[ 5004 ];
int DP[ 2 ][ 10001 ];
int main()
{
fin >> N >> Gmax;
for (i = 1; i <= N; ++i)
fin >> G[i] >> P[i];
for (i = 1; i <= N; ++i)
{
for (gc = 0; gc <= Gmax; ++gc)
{
if (i % 2)
ind_aux = 0;
else
ind_aux = 1;
DP[i % 2][gc] = DP[ind_aux][gc];
if (G[i % 2] <= gc)
DP[i % 2][gc] = max(DP[ind_aux][gc - G[i]] + P[i] , DP[ind_aux][gc]);
}
}
fout << DP[N % 2][Gmax] << '\n';
return 0;
}