Cod sursa(job #2609098)

Utilizator sebastianp2003Popa Sebastian sebastianp2003 Data 2 mai 2020 10:36:27
Problema Factorial Scor 90
Compilator cpp-64 Status done
Runda igorj_mentorat1 Marime 0.78 kb
#include <bits/stdc++.h>
using namespace std;
ifstream f("fact.in");
ofstream g("fact.out");
unsigned long long n, rez;
unsigned long long calc(unsigned long long);
int main()
{
    f >> n;
    if (!n)
        g << 1, g.flush(), exit(0);
    unsigned long long st = 1ll, dr = 1ll * 1000 * 1000 * 1000 * 5;
    while (st <= dr)
    {
        unsigned long long mid = st + ((dr - st) >> 1);
        unsigned long long ax = calc(mid);
        if (n == ax)
            rez = mid, dr = mid - 1;
        else if (ax < n)
            st = mid + 1;
        else
            dr = mid - 1;
    }
    g << rez;
    return 0;
}
unsigned long long calc(unsigned long long x)
{
    unsigned long long p = 5, r = 0;
    while (p <= x)
        r += x / p, p *= 5;
    return r;
}