Pagini recente » Cod sursa (job #2223231) | Cod sursa (job #759260) | Cod sursa (job #537537) | Cod sursa (job #1901048) | Cod sursa (job #291553)
Cod sursa(job #291553)
#include<stdio.h>
long fives(long x){
long nr = 0,cat=5;
while( cat <= x ){
nr+= x / cat;
cat*=cat;
}
return nr;
}
int main(){
FILE *f=fopen("fatorial.in","r");
FILE *g=fopen("factorial.out","w");
long k;
fscanf(f,"%lld",&k);
long st = 1;
long dr = 1024;
long mj,n=0,nn;
while(st<=dr){
mj = (st+dr)>>1;
nn = fives(mj);
if( nn < k ) st = mj + 1;
else if ( nn == k ) n = mj;
else dr = mj - 1;
}
if( fives(n) == k) fprintf(g,"%lld",n);
else fprintf(g,"-1");
return 0;
}