这道题是LeetCode里的第172道题。
题目描述:
给定一个整数 n,返回 n! 结果尾数中零的数量。
示例 1:
输入: 3 输出: 0 解释: 3! = 6, 尾数中没有零。示例 2:
输入: 5 输出: 1 解释: 5! = 120, 尾数中有 1 个零.说明: 你算法的时间复杂度应为 O(log n) 。
0 来源于 2 * 5,因为在阶乘中,因子 2 肯定比因子 5 多,所以我们只要统计 5 的个数就行了。
解题代码:
class Solution {
public int trailingZeroes(int n) {
int count = 0;
while(n >= 5){
count += n / 5;
n /= 5;
}
return count;
}
}
提交结果:

个人总结:
起初还统计了 2 的个数,绕了个弯。

博客围绕LeetCode第172题展开,题目要求给定整数n,返回n!结果尾数中零的数量,且算法时间复杂度应为O(log n)。解题关键在于,由于阶乘中因子2比因子5多,只需统计5的个数。作者起初还统计2的个数绕了弯。

1332

被折叠的 条评论
为什么被折叠?



