Pagini recente » Cod sursa (job #1447817) | Cod sursa (job #3139534) | Cod sursa (job #105509) | Cod sursa (job #2351813) | Cod sursa (job #2577205)
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("fact.in");
ofstream out("fact.out");
unsigned long long int numar(unsigned long long int n){
unsigned long long int p=5,rasp=0;
while(p<=n){
rasp+=n/p;
p*=5;
}
return rasp;
}
int main()
{
unsigned long long int p;
in>>p;
if(p==0)
{
out<<1;
return 0;
}
unsigned long long int st,dr,mij,sol=0,n;
st=1,dr=400000016;
while(st<=dr)
{
mij=(st+dr)/2;
n=numar(mij);
if(n<p)
{
st=mij+1;
}
else
{
if(n==p) sol=mij;
dr=mij-1;
}
}
if(sol==0)
{
out<<"-1";
return 0;
}
out<<sol;
}