首页 > 其他 > 详细

Leet Code OJ 172. Factorial Trailing Zeroes [Difficulty: Easy]

时间:2016-03-07 13:56:42      阅读:241      评论:0      收藏:0      [点我收藏+]

题目:
Given an integer n, return the number of trailing zeroes in n!.

Note: Your solution should be in logarithmic time complexity.

翻译:
给定一个整数n,返回n!末尾的0的个数。
提示:你的解决方案应该运行在O(log(n))的时间复杂度。

分析:
我们知道要形成一个末尾的0,需要组合出2和5这两个质因子。然而在n!中,质因子2的个数永远大于5的个数。所以,问题转换为对n!计算5的质因子个数。

代码:

public class Solution {
    public int trailingZeroes(int n) {
        int s=0;
        while(n>=5){
            n/=5;
            s+=n;
        }
        return s;   
    }
}

Leet Code OJ 172. Factorial Trailing Zeroes [Difficulty: Easy]

原文:http://blog.csdn.net/lnho2015/article/details/50818372

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!