Pagini recente » Cod sursa (job #1602573) | Cod sursa (job #2612206) | Cod sursa (job #2735447) | Cod sursa (job #2447075) | Cod sursa (job #3157708)
#include <bits/stdc++.h>
#define MAX 510000000
using namespace std;
ifstream fin("fact.in");
ofstream fout("fact.out");
int nr(int x)
{
int f=5, NR=0;
while(f<=x)
{
NR+=(x/f);
f*=5;
}
return NR;
}
unsigned long long caut_binar(int x)
{
unsigned long long st=1;
unsigned long long dr=MAX;
unsigned long long ans=-1;
while(st<=dr)
{
long long mij = (st+dr)/2;
int nr_zero = nr(mij);
if(x<=nr_zero)
{
dr=mij-1;
ans=mij;
}
else st=mij+1;
}
return ans;
}
int z;
int main()
{
fin >> z;
unsigned long long C = caut_binar(z);
if(nr(C)==z)fout << C;
else fout << -1;
return 0;
}