Pagini recente » Cod sursa (job #340613) | Cod sursa (job #2670521) | Cod sursa (job #775852) | Cod sursa (job #2115093) | Cod sursa (job #3001540)
#include <iostream>
#include <fstream>
#include <climits>
using namespace std;
ifstream fin("fact.in");
ofstream fout("fact.out");
int putericinci(unsigned long long int x)
{
unsigned long long int c=0,p=5;
while(p<=x)
{
c+=x/p;
p*=5;
}
return c;
}
int main()
{
unsigned long long int n;
fin>>n;
unsigned long long int poz=0;
unsigned long long int stanga=1,dreapta=1E18;
while(stanga<=dreapta)
{
unsigned long long int mijloc=stanga+(dreapta-stanga)/2;
//cout<<stanga<<" "<<dreapta<<" "<<mijloc<<'\n';
int x=putericinci(mijloc);
if(x==n)
dreapta=mijloc-1,poz=mijloc;
else if(x<n)
stanga=mijloc+1;
else
dreapta=mijloc-1;
}
if(poz==0)
fout<<-1;
else
fout<<poz-poz%5;
return 0;
}