Pagini recente » Cod sursa (job #995217) | Cod sursa (job #2207497) | Cod sursa (job #39104) | Cod sursa (job #3135268) | Cod sursa (job #557885)
Cod sursa(job #557885)
#include<stdio.h>
#define GMax 1002
#define WMax 5002
FILE *f=fopen("energii.in","r");
FILE *g=fopen("energii.out","w");
int G,W,C[WMax][GMax];
int E[GMax],Cost[GMax];
void Completare(int i,int j)
{int k;
k = i - E[j];
if(k >= 1 && C[k][j-1] + Cost[j] < C[i][j-1])
{C[i][j] = Cost[j] + C[k][j-1]; return;}
else
if(k <= 0 && Cost[j] < C[i][j-1])
{C[i][j] = Cost[j]; return; }
else
{C[i][j]=C[i][j-1]; return; }
}
void Read()
{int i;
fscanf(f,"%d %d",&G,&W);
for(i=1;i<=G;i++)
fscanf(f,"%d %d",&E[i],&Cost[i]);
fclose(f);
}
int main()
{int i,j;
Read();
for(i = 1 ;i <= W; i++)
C[i][0] = 10001;
for(i = 1 ;i <= W; i++)
for(j=1;j<=G;j++)
Completare(i,j);
if(C[W][G]==10001)
fprintf(g,"-1\n");
else
fprintf(g,"%d\n",C[W][G]);
fclose(g);
return 0;
}