Pagini recente » Cod sursa (job #1645368) | Cod sursa (job #2142106) | Cod sursa (job #473323) | Cod sursa (job #2595366) | Cod sursa (job #991052)
Cod sursa(job #991052)
#include <fstream>
#define NMax 5005
#define GMax 10005
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int N,G,W[NMax],P[NMax],DP[2][GMax],l=1;
void Read()
{
fin>>N>>G;
for(int i=1;i<=N;i++)
{
fin>>W[i]>>P[i];
}
}
void Solve()
{
for(int i=1;i<=N;i++,l=1-l)
for(int j=1;j<=G;j++)
{
DP[l][j]=DP[1-l][j];
if(j>=W[i])
DP[l][j]=max(DP[l][j],DP[1-l][j-W[i]]+P[i]);
}
}
void Print()
{
fout<<DP[1-l][G]<<'\n';
}
int main()
{
Read();
Solve();
Print();
return 0;
}