Pagini recente » Cod sursa (job #3282579) | Cod sursa (job #2948988) | Cod sursa (job #720230) | Cod sursa (job #2383159) | Cod sursa (job #1888928)
#include <fstream>
long p, n, nup = -1, ndown;
bool fact(long num)
{
n = 0;
while(num != 0)
num /= 5, n += num;
return (n >= p);
}
void search_min()
{
if(ndown < nup)
if(fact((ndown + nup)/2))
nup = (ndown + nup)/2, search_min();
}
int main()
{
std::ifstream f("fact.in");
std::ofstream g("fact.out");
f>>p;
if(p == 0) nup = 1;
else if(p >= 0)
ndown = p*4, nup = p*5, search_min();
while(fact(nup-1))
nup--;
if(!fact(nup))
g<<-1;
else
g<<nup<<"\n";
return 0;
}