题目
给定一个整数 n,返回 n! 结果尾数中零的数量。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/factorial-trailing-zeroes
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
示例
示例 1:
输入: 3
输出: 0
解释: 3! = 6, 尾数中没有零。
示例 2:
输入: 5
输出: 1
解释: 5! = 120, 尾数中有 1 个零.
说明: 你算法的时间复杂度应为 O(log n) 。
解答
算出n的阶乘,再计算末尾有几个0.
class Solution:
def trailingZeroes(self, n: int) -> int:
num = 1
sum = 0
for i in range(1, n + 1):
num = num * i
print(num)
while True:
if num % 10 == 0:
sum = sum + 1
num = num // 10
else:
return sum
if __name__ == '__main__':
res = Solution().trailingZeroes(10)
print(res)
这样是做出来了,但是会超时,还得优化一下。