Cod sursa(job #1199307)

Utilizator teodor440Teodor Tonghioiu teodor440 Data 18 iunie 2014 19:49:06
Problema Factorial Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.58 kb
#include <iostream>
#include <fstream>

using namespace std;

ifstream f("fact.in");
ofstream g("fact.out");

long long v[19];

long fct(long long &x){
    long k=0;
    for(int i=0;i<=18||x<v[i];i++) k+=x/v[i];
    return k;
}

int main()
{
    long long p,s,d,a;
    v[0]=5;
    for(int i=1;i<=18;i++) v[i]=v[i-1]*5;
    long x;
    f>>p;
    s=0;
    d=p*5;
    while(s<d){
        a=(s+d)/2;
        x=fct(a);
        if(x==p){ g<<a-a%5<<endl; return 0; }
        else if(x>p) d=a-1;
        else s=a+1;
    }
    a=d-5;
    g<<-1<<endl;


    return 0;
}