Cod sursa(job #2197025)
Utilizator | Data | 20 aprilie 2018 22:03:11 | |
---|---|---|---|
Problema | Factorial | Scor | 75 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.62 kb |
#include <iostream>
#include <cstdio>
using namespace std;
int numarzero(int n)
{
int nr=0;
while(n!=0)
{
nr=nr+n/5;
n=n/5;
}
return nr;
}
int main()
{
freopen("fact.in","r",stdin);
freopen("fact.out","w",stdout);
int P; scanf("%d", &P);
int m,u,p;
p=1;
u=5*P+50;
while (p<=u)
{
m = (p+u)/2;
if (numarzero(m)>=P)
u = m-1;
else
p = m+1;
}
int suma=5;
while(suma<P)
suma=suma+6;
if(suma==P)
cout<<-1;
else
cout<<p;
return 0;
}