Cod sursa(job #833267)

Utilizator anamariaaAvram Ana-Maria anamariaa Data 12 decembrie 2012 10:14:28
Problema Factorial Scor 60
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.63 kb
#include<fstream>
using namespace std;
 
long long f(long long x)
{
    int p=5,nr=0;
    while (p<=x)
    {
        nr=nr+x/p;
        p=p*5;
    }
    return nr;
}
 
int main()
{
    ifstream fin("fact.in");
    ofstream fout("fact.out");
    long long p, max=100000000, min=0, x, m;
    fin>>p;
    if (p==0) min=1;
        else while (min<max)
            {
                x=(min+max)/2;
                if (x<5) m=0;
                    else m=f(x);
                if (m<p) min=x+1;
                    else max=x;
            }       
    if (f(min)==p) fout<<min;
        else fout<<"-1";
    return 0;
}