尾部0的数量取决于因子5的数量

有关阶乘的两个问题1

http://www.nowcoder.com/questionTerminal/aa03dff18376454c9d2e359163bf44b8

能够在尾部得出0,是由于存在局部的2*5,而在阶乘中,能够提取的2的数量一定大于5的数量,所以尾部0的数量取决于能够提取出多少个因子5,那么从1到n能提取出多少个5呢?这里有一个公式:
对于一个数N,它所包含5的个数为:N/5 + N/52 + N/53 + ...,其中N/5表示不大于N的数中5的倍数贡献一个5,N/52表示不大于N的数中52的倍数再贡献一个5……

因此,可以采用递归或者迭代的方式求解:

    public long thenumberof0 (long n) {
        // write code here

        if (n < 5){
            return 0;
        }


        return n / 5 + thenumberof0(n / 5);
    }
全部评论

相关推荐

但听说转正率很低,我现在有在实习了,好纠结要不要去
熬夜脱发码农:转正率低归低,但是实习的经历你可以拿着,又不是说秋招不准备了
点赞 评论 收藏
分享
下个早班:秒挂就是不缺人
点赞 评论 收藏
分享
05-20 21:57
已编辑
门头沟学院 Java
喜欢吃卤蛋的悲伤蛙在...:建信融通没消息吧,我2说有实习挂简历不理了
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务