Trailing Zeroes (III) (数学)

来源:互联网 发布:软件语言培训学校 编辑:程序博客网 时间:2024/05/21 18:44

You task is to find minimal natural number N, so that N! contains exactly Q zeroes on the trail in decimal notation. As you know N! = 1*2*...*N. For example, 5! = 120, 120 contains one zero on the trail.

Input

Input starts with an integer T (≤ 10000), denoting the number of test cases.

Each case contains an integer Q (1 ≤ Q ≤ 108) in a line.

Output

For each case, print the case number and N. If no solution is found then print 'impossible'.

Sample Input

3

1

2

5

Sample Output

Case 1: 5

Case 2: 10

Case 3: impossible


【题意】输入一个数,表示阶乘值末尾0的个数,求满足条件的最小数。

  这道题的关键在于怎么知道一个数阶乘值末尾0的个数,因为数据庞大,不可能正常计算出来,所以就要采取一定的数学方法,经过尝试可以知道,1~4的阶乘值末尾没有0,5~9的阶乘值末尾一个0,10~14的阶乘值末尾2个0,但是!!!末尾三个0的数没有,所以用而二分就可以找出这样的数,具体看代码:

#include<iostream>#include<cstdio>#include<cstring>using namespace std;typedef long long LL;LL ans(LL n){    LL ss=0;    while(n)    {        ss+=n/5;        n/=5;    }    return ss;}int main(){    int t;    LL m,a;    scanf("%d",&t);    for(int i=1;i<=t;i++)    {        scanf("%lld",&m);        LL l=1,r=1e12;        a=0;        while(r>=l)        {            LL mid=(l+r)>>1;            if(ans(mid)==m)            {                a=mid;                r=mid-1;            }            else if(ans(mid)>m)                r=mid-1;            else                l=mid+1;        }        if(a)        printf("Case %d: %lld\n",i,a);        else            printf("Case %d: impossible\n",i);    }    return 0;}


原创粉丝点击