Pagini recente » Borderou de evaluare (job #2192460) | Borderou de evaluare (job #525186) | Borderou de evaluare (job #2399626) | Borderou de evaluare (job #2608209) | Cod sursa (job #809782)
Cod sursa(job #809782)
#include<fstream>
using namespace std;
long long f(long long x)
{
int p=5,nr=0;
while (p<=x)
{
nr=nr+x/p;
p=p*5;
}
return nr;
}
int main()
{
ifstream fin("fact.in");
ofstream fout("fact.out");
long long p, max=100000000, min=0, x, m;
fin>>p;
if (p==0) min=1;
else while (min<=max)
{
x=(min+max)/2;
if (x<5) m=0;
else m=f(x);
if (m<p) min=x+1;
else max=x-1;
}
if (f(min)==p) fout<<min;
else fout<<"-1";
return 0;
}