Pagini recente » Cod sursa (job #2273124) | Cod sursa (job #958429) | Cod sursa (job #1651775) | Cod sursa (job #1215869) | Cod sursa (job #1510046)
#include <fstream>
using namespace std;
ifstream fin("fact.in");
ofstream fout("fact.out");
long long int p;
long long int powFiveSmallerThanX(long long int x) {
long long int n = 5, pow = 1;
while (n <= x) {
++pow;
n *= 5;
}
--pow;
return pow;
}
long long int howManyFives(long long int x) {
long long int w = 5, s = 0;
for (long long int i = 1; i <= powFiveSmallerThanX(x); ++i) {
s += x / w;
w *= 5;
}
return s;
}
void binarySearch() {
long long int lmtL = 5, lmtR = p * 5;
long long int pivot = (lmtL + lmtR) / 2;
while (howManyFives(pivot) != p) {
if (howManyFives(pivot) > p) {
lmtR = pivot;
pivot = (lmtL + lmtR) / 2;
if (lmtL == lmtR - 1) {
fout << lmtR;
return;
}
}
else {
lmtL = pivot;
pivot = (lmtL + lmtR) / 2;
if (lmtL == lmtR - 1) {
fout << lmtR;
return;
}
}
}
if (howManyFives(pivot - 1) == p) --pivot;
while (pivot % 5 != 0)
--pivot;
fout << pivot;
}
int main()
{
fin >> p;
if (p == 0) fout << 1;
else binarySearch();
return 0;
}