Leetcode--172. 阶乘后的零
发布日期:2021-04-30 21:00:36 浏览次数:139 分类:精选文章

本文共 592 字,大约阅读时间需要 1 分钟。

给定一个整数n,计算n!(n的阶乘)末尾零的数量。这个问题可以通过分析因数分解来解决。

阶乘末尾的零的数量取决于因数10的数量,而10是由2和5相乘得到的。由于2的数量通常比5多,因此末尾零的数量由5的数量决定。

要计算n!中5的数量,可以使用以下方法:

  • 初始化sum为0。
  • 进入一个循环,条件为n >= 5。
  • 在每次循环中,将sum加上n除以5的商,然后将n更新为n除以5的结果。
  • 当n小于5时,循环结束。
  • 这个方法的时间复杂度是O(log n),因为每次循环n都被除以5,直到n小于5。

    代码实现

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

    代码解释

  • 初始化sum:将sum初始化为0,用于记录末尾零的数量。
  • 循环处理:使用while循环,当n大于等于5时继续执行。
    • sum += n / 5:将当前n除以5的商加到sum中,表示这部分因数5贡献的末尾零数量。
    • n = n / 5:将n更新为n除以5的结果,继续处理更高的幂次(如25、125等)。
  • 返回结果:当循环结束时,sum即为n!末尾零的数量。
  • 这个实现简洁高效,能够在O(log n)的时间内解决问题。

    上一篇:Arrays类
    下一篇:CSS基础知识点总结、一

    发表评论

    最新留言

    网站不错 人气很旺了 加油
    [***.192.178.218]2026年06月02日 02时06分43秒