美文网首页
99的阶乘分析

99的阶乘分析

作者: enjoycc97 | 来源:发表于2019-08-13 19:34 被阅读0次

    99的阶乘分析

    主要是分析一些特征,当然这里可能先不会直接去求这个数

    这个数字末尾有0吗,如果有,数量是多少

    可能99!太复杂,一般先分析简单的。比如5!,6!,7!,8!
    5!=54321=120 结尾是1个0
    8!=87654321=40320
    这里面特征就是这个数可以被5整除吗?
    比如120=5
    4321中有1个5则结尾就是1个0,8也是一样只有1个5.
    当然如果是10也可以,比如3628800=10
    987654321含有1个5,
    1个10,则被5整除的数字有2个,3628800结尾就是有2个0
    实际上125这种还要处理一下,125*4=600是有2个0的,对于125/5=25还能继续被5整除,也就是25/5=1也是可以的
    参考代码如下:

        int countFactorial0Size(int data) {
            int sum = 0;
            for (int i = 1; i <= data; i++) {
                int tmp = 0;
                int count = i;
                while (count % 5 == 0) {
                    count = count / 5;
                    tmp++;
                }
                sum += tmp;
            }
            return sum;
        }
    

    这个数字的二进制末尾有0吗,如果有,数量是多少

    继续分析二进制特点比如十进制11对应的二进制也就是1011,末尾是1,所以末尾1个0都没有,对于奇数特点就是末尾是1,所以奇数末尾一个0都没有啦
    分析偶数比如8,二进制是1000,末尾3个0,可以通过右移3位得出数字末尾是1了;
    分析10呢,对应二进制是1010,通过右移1位得出数字末尾是1了;
    右移1位代表除以2,那么1010,看看这个数能被2除以几次呢?如果是10,除以2就变成奇数了,也就是二进制第一位是1了,说明10的二进制末尾只有1个0;
    所以10的阶乘,1098765432*1,看看这个数字除以2到什么时候才会
    变成奇数,除以1次说明二进制末尾1个0,除以10次末尾就有10个0
    参考代码:

     int countFactorBinZeroSize(int data) {
            int sum = 0;
            for (int i = 1; i <= data; i++) {
                int tmp = i;
                int count = 0;
                while ((tmp & 1) == 0) {
                    count++;
                    tmp = tmp >> 1;
                }
                sum += count;
            }
            return sum;
     }
    

    找到这个数字,是,与推理出来的效果是一模一样的

    99!=933262154439441526816992388562667004907159682643816214685929638952175999932299156089414639761565182862536979208272237582511852109168640000000000000000000000
    算出结果0的个数22
    二进制个数95个

    相关文章

      网友评论

          本文标题:99的阶乘分析

          本文链接:https://www.haomeiwen.com/subject/cyzbjctx.html