Cod sursa(job #1488475)

Utilizator NineshadowCarapcea Antonio Nineshadow Data 19 septembrie 2015 02:07:02
Problema Factorial Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.75 kb
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("fact.in");
ofstream out("fact.out");
long no_0(long n)
{
    int k=0;
    long x=5;
    while(x<=n)
    {
        k+=n/x;
        x*=5;
    }
    return k;
}
int main()
{
    int p;
    in>>p;
    if(p==0)
    {
        out << 1;
        return 0;
    }
    long r = -1;
    long st = 0;
    long dr = 5*100000000;
    long q;
    while(st < dr)
    {
        q = (st+dr)/2;
        if(no_0(q)==p)
        {
            r = q;
            break;
        }
        else if(no_0(q) < p) st = q + 1;
        else dr=q-1;
    }
    if(r!=-1)
    for(long i = 3; i>=0; i--)
    {
        if(r%5==0)break;
        r--;
    }
    out<<r;
    return 0;
}