Cod sursa(job #1943266)

Utilizator nicu_serteSerte Nicu nicu_serte Data 28 martie 2017 14:38:25
Problema Factorial Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.74 kb
#include <fstream>
#include <climits>
using namespace std;
ifstream fin("fact.in");
ofstream fout("fact.out");
int p;
int nrz(int n)
{
    int nr=0, p=5;
    while(p<=n)
    {
        nr=nr+n/p;
        p*=5;
    }
    return nr;
}
int main()
{
    long long st, dr, m, nr;
    fin>>p;
    fin.close();
    if(p==0)
    {
        fout<<1<<'\n';
        fout.close();
        return 0;
    }
    st=0; dr=INT_MAX-1;
    while(st<=dr)
    {
        m=(st+dr)/2;
        nr=nrz(m);
        if(nr==p)
        {
            fout<<m-m%5<<'\n';
            fout.close();
            return 0;
        }
        if(nr<p)
            st=m+1;
        else dr=m-1;
    }
    fout<<"-1\n";
    fout.close();
    return 0;
}