Python算法例31 阶乘尾部零的个数

1. 问题描述

计算n的阶乘中尾部零的个数。

2. 问题示例

输入11,输出2,11!=39916800,结尾有2个0;输入5,输出1,5!=120,结尾有1个0。

3. 代码实现

def trailing_zeros(n):
    count = 0
    while n >= 5:
        n //= 5
        count += n
    return count

# 测试样例
print(trailing_zeros(11))  # 输出2
print(trailing_zeros(5))   # 输出1

该算法的思路是,一个零的出现是由于2和5相乘得到的,而阶乘中2的数量远大于5的数量。因此,我们只需要计算阶乘中包含多少个5即可。

在循环中,我们将n除以5,并将结果加到计数器count上。然后,将n除以5继续进行循环操作,直到n小于5为止。最后,返回count的值即为尾部零的个数。

这种算法的时间复杂度为O(\log n),其中n为输入的数字。

要计算尾部零的个数,我们可以观察到,尾部零的个数取决于阶乘中因子5的个数。因为每个因子5都能与一个偶数相乘得到10,进而贡献一个尾部零。

更优的算法是利用数学的方法来计算因子5的个数,而不需要遍历每个数字。

def trailing_zeros(n):
    count = 0
    while n >= 5:
        n //= 5
        count += n
    return count

# 测试样例
print(trailing_zeros(11))  # 输出2
print(trailing_zeros(12))   # 输出2

这个算法的时间复杂度仍然是O(\log n),但是它比遍历每个数字的方法要快得多。它通过将n除以5来计算因子5的个数,并将结果累加到计数器count上。然后,将n除以5继续进行循环操作,直到n小于5为止。最后,返回count的值即为尾部零的个数。

这种算法利用了因子5的特性,能够更高效地计算尾部零的个数。

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北辰星Charih

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值