Pagini recente » Cod sursa (job #1620022) | Cod sursa (job #1062881) | Cod sursa (job #2786535) | Cod sursa (job #603841) | Cod sursa (job #2534955)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin ("fact.in");
ofstream fout ("fact.out");
int zerouri(int x)
{
int cnt=0;
while(x>0)
{
cnt+=x/5;
x/=5;
}
return cnt;
}
int main()
{
long long p,mijloc,dreapta,stanga;
fin >> p;
stanga=1;
dreapta=100000001;
if(p!=0)
{
while ( dreapta - stanga > 1 )
{
mijloc = (stanga + dreapta) / 2;
if (zerouri(mijloc) >p)
dreapta = mijloc;
else
stanga = mijloc;
}
while(zerouri(stanga)==p)
stanga--;
stanga++;
}
if(p==0)
stanga=1;
if(zerouri(stanga)==p)
fout << stanga;
else
fout << -1;
return 0;
}