Pagini recente » Cod sursa (job #2681232) | Cod sursa (job #2517233) | Cod sursa (job #801592) | Cod sursa (job #2938791) | Cod sursa (job #1888915)
#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--;
g<<nup<<"\n";
return 0;
}