Pagini recente » Cod sursa (job #3269871) | Cod sursa (job #79852) | Cod sursa (job #17418) | Rating Cantea Andrei (andreicantea) | Cod sursa (job #1768625)
#include <cstdio>
using namespace std;
int put5[15];
long long nr0(int n)
{
long long r=n/5;
int i;
for(i=1; i<=13 && n>=put5[i]; i++)
r+=i-1;
return r;
}
int main()
{ //freopen("fact.in", "r",stdin);
//freopen("fact.out", "w",stdout);
int p,i,pas;
scanf("%d", &p);
put5[0]=1;
for(i=1; i<=13; i++)
put5[i]=5*put5[i-1];
i=0;
pas=1<<30;
while(pas!=0){
if(i+pas<=2147483648 && nr0(i+pas)<p)
i+=pas;
pas/=2;
}
if(nr0(i+1)==p)
printf("%d", i+1);
else
printf("-1");
return 0;
}