Cod sursa(job #2758977)
| Utilizator | Data | 14 iunie 2021 18:53:33 | |
|---|---|---|---|
| Problema | Factorial | Scor | 100 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva de probleme | Marime | 0.71 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin("fact.in");
ofstream fout("fact.out");
int P;
int nrz(int x)
{
int s = 0;
while(x)
{
s += x / 5;
x /= 5;
}
return s;
}
void rezolva()
{
int r = -1, st = 1, dr = 2000000000, mij;
while(st <= dr)
{
mij = (st + dr) / 2;
int s = nrz(mij);
if(s < P)
{
st = mij + 1;
}
else if(s == P)
{
r = mij;
dr = mij - 1;
}
else if(s > P)
{
dr = mij - 1;
}
}
fout << r << '\n';
}
int main()
{
fin >> P;
rezolva();
return 0;
}
