Cod sursa(job #1704698)
Utilizator | Data | 19 mai 2016 11:07:44 | |
---|---|---|---|
Problema | Factorial | Scor | 100 |
Compilator | c | Status | done |
Runda | Arhiva de probleme | Marime | 0.42 kb |
#include <stdio.h>
int zero(int n){
int nr=0;
while (n>=5)
nr+=(n/=5);
return nr;
}
int main()
{
FILE *fin,*fout;
int p2,p,i;
fin=fopen("fact.in","r");
fout=fopen("fact.out","w");
fscanf(fin,"%d", &p);
for (i=0,p2=1<<30;p2>0;p2/=2)
if (zero(i+p2)<p)
i+=p2;
if (zero(i+1)==p)
fprintf(fout,"%d", i+1);
else
fprintf(fout,"-1");
return 0;
}