Cod sursa(job #2631777)

Utilizator sebastianp2003Popa Sebastian sebastianp2003 Data 1 iulie 2020 00:31:13
Problema Factorial Scor 90
Compilator cpp-64 Status done
Runda Arhiva de probleme Marime 0.69 kb
#include <bits/stdc++.h>
using namespace std;
ifstream f("fact.in");
ofstream g("fact.out");
bool check(long long, long long);
int main()
{
    long long n, rez;
    f >> n;
    long long st = 1, dr = LLONG_MAX / 2;
    while (st <= dr)
    {
        long long mid = st + (dr - st) / 2;
        if (check(mid, n))
            rez = mid, dr = mid - 1;
        else
            st = mid + 1;
    }
    g << rez;
    return 0;
}
bool check(long long nr, long long mn)
{
    long long n2 = 0;
    for (long long t = 2; nr / t > 0; t *= 2)
        n2 += nr / t;
    long long n5 = 0;
    for (long long t = 5; nr / t > 0; t *= 5)
        n5 += nr / t;
    return min(n2, n5) >= mn;
}