Pagini recente » Cod sursa (job #2676057) | Cod sursa (job #2636082) | Cod sursa (job #2319885) | Cod sursa (job #1355779) | Cod sursa (job #1377861)
#include <fstream>
using namespace std;
ifstream in("rucsac.in");
ofstream out("rucsac.out");
int N,G,v[10001],w[10001],m[3][10001];
int main()
{
in>>N>>G;
for(int i=1;i<=N;i++)
{
in>>w[i]>>v[i];
}
for(int j=0;j<=G;j++)
{
if(w[1]<=j)
{
m[1][j]=v[1];
}
}
for(int i=2;i<=N;i++)
{
for(int j=0;j<=G;j++)
{
if(w[i]<=j)
{
m[2][j]=max(m[1][j], m[1][j-w[i]]+v[i]);
}
else
{
m[2][j]=m[1][j];
}
}
for(int j=0;j<=G;j++)
{
swap(m[1][j],m[2][j]);
}
}
out<<m[1][G];
return 0;
}