Pagini recente » Cod sursa (job #2674967) | Istoria paginii runda/unmicwarmup | Cod sursa (job #40940) | Cod sursa (job #201698) | Cod sursa (job #2023997)
#include <fstream>
using namespace std;
ifstream fin("rucsac.in");
ofstream fout("rucsac.out");
int a1[10002];
int a2[10002];
int gr[5002];
int pr[5002];
int main()
{
int n,GR;
fin>>n>>GR;
for(int i=1;i<=n;i++)
{
fin>>gr[i]>>pr[i];
}
for(int i=gr[1];i<=GR;i++)
{
a1[i]=pr[1];
}
for(int i=2;i<=n;i++)
{
for(int j=0;j<=GR;j++)
{
a2[j]=a1[j];
if(gr[i]<=j)
{
a2[j]=max(a2[j],a1[j-gr[i]]+pr[i]);
}
}
for(int j=1;j<=GR;j++)
{
a1[j]=a2[j];
}
}
fout<<a2[GR];
return 0;
}