Pagini recente » Cod sursa (job #2965301) | Cod sursa (job #1950607) | Cod sursa (job #1802388) | Cod sursa (job #1392577) | Cod sursa (job #2345381)
#include<cstdio>
using namespace std;
int legendre(int n)
{
int p=5,p1=5,s=0;
while(p1<n)
{
s+=n/p1;
p1*=p;
}
return s;
}
int bs(int st, int dr, int val)
{
int med=(st+dr)/2;
while(st<=dr)
{
med=(st+dr)/2;
if(legendre(med)>val) dr=med-1;
else if(legendre(med)<val) st=med+1;
else return med;
}
return -1;
}
int main()
{
freopen("fact.in","r",stdin);
freopen("fact.out","w",stdout);
int p,ans;
scanf("%d",&p);
if(p==0) printf("1");
else if(p==1) printf("5");
else
{
ans=bs(1,2100000000,p);
while(legendre(ans)==p)
ans--;
ans++;
printf("%d",ans);
}
return 0;
}