Cod sursa(job #2101647)
Utilizator | Data | 7 ianuarie 2018 19:12:43 | |
---|---|---|---|
Problema | Factorial | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.41 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin("fact.in");
ofstream fout("fact.out");
int zero(int n)
{
int nr=0;
while(n>=5)
nr+=(n/=5);
return nr;
}
int main()
{
long long n,r=0,pas;
fin>>n;
pas=1<<30;
while(pas)
{
if(zero(r+pas)<n)
r+=pas;
pas/=2;
}
fout<<(zero(r+1)==n? r+1:-1);
return 0;
}