Cod sursa(job #1009594)
| Utilizator | Data | 13 octombrie 2013 15:44:38 | |
|---|---|---|---|
| Problema | Factorial | Scor | 45 |
| Compilator | cpp | Status | done |
| Runda | Arhiva de probleme | Marime | 0.6 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("fact.in");
ofstream fout("fact.out");
int factorial(int x)
{
int i,nr=0;
for(i=5;i<=x;i*=5)
nr+=x/i;
return nr;
}
int main()
{
unsigned p;
fin >> p;
long long int a=1,b=p*5,c;
if(p==0)
fout << 1 << "\n";
else
{while(a!=b)
{
c=(a+b)/2;
if(factorial(c)>=p)
b=c-1;
if(factorial(c)<p)
a=c+1;
}
if(factorial(a)==p)
fout << a << "\n";
else
fout << -1 << "\n";}
return 0;
}
