Pagini recente » Cod sursa (job #991078) | Cod sursa (job #2560575) | Cod sursa (job #45402) | Cod sursa (job #739586) | Cod sursa (job #1368358)
#include<stdio.h>
int pack[2][5001],weight[5001],val[5001],pos=1;
int main()
{
FILE *fin,*fout;
fin=fopen("rucsac.in","r");
fout=fopen("rucsac.out","w");
int n,g;
fscanf(fin,"%d %d",&g,&n);
for(int i=1;i<=n;i++)
{
fscanf(fin,"%d %d",&weight[i],&val[i]);
}
for(int i=weight[pos];i<=n;i++)
{
pack[0][i]=val[pos];
}
pos++;
for(int i=2;i<=g;i++)
{
for(int i=weight[pos];i<=n;i++)
{
if(pack[0][i]>pack[0][i-weight[pos]]+val[pos])
{
pack[1][i]=pack[0][i];
}
else
{
pack[1][i]=pack[0][i-weight[pos]]+val[pos];
}
}
for(int i=1;i<=n;i++)
{
//fprintf(fout,"%d ",pack[1][i]);
pack[0][i]=pack[1][i];
}
//fprintf(fout,"\n");
pos++;
}
fprintf(fout,"%d",pack[1][n]);
}