题目
给定一个整数 n,返回 n! 结果尾数中零的数量。
示例 1:
输入: 3
输出: 0
解释: 3! = 6, 尾数中没有零。
示例 2:
输入: 5
输出: 1
解释: 5! = 120, 尾数中有 1 个零.
说明: 你算法的时间复杂度应为 O(log n) 。
代码模板:
class Solution {
public int trailingZeroes(int n) {
}
}
分析
阶乘里面一个5的倍数是一个0,两个5的倍数是2个0,所以循环,直接用这个阶乘/5就是要加的0的个数。
解答
class Solution {
public int trailingZeroes(int n) {
int sum = 0;
while(n > 0){
sum = sum + n / 5;
n = n / 5;
}
return sum;
}
}

本文解析了如何高效计算阶乘结果中尾数零的数量,采用除以5的倍数计数法,实现O(logn)时间复杂度的算法。通过实例演示,如输入5,输出1(5!=120),揭示了算法背后的数学原理。
216

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



