n!尾随零的数量

给定一个整数 n ,返回 n! 结果中尾随零的数量。

提示 n! = n * (n - 1) * (n - 2) * ... * 3 * 2 * 1

示例 1:

复制代码
输入:n = 3
输出:0
解释:3! = 6 ,不含尾随 0

示例 2:

复制代码
输入:n = 5
输出:1
解释:5! = 120 ,有一个尾随 0

示例 3:

复制代码
输入:n = 0
输出:0

提示:

  • 0 <= n <= 104

统计因子 5

cpp 复制代码
class Solution {
public:
    int trailingZeroes(int n) {
        int count = 0;
        // 统计 n! 中的因子 5 的个数
        while (n >= 5) {
            n /= 5;
            count += n;
        }
        return count;
    }
};

基于尾随零的产生机制:每有一个因子 10,就会在数的末尾增加一个尾随零 。而 10 可以拆分成 2 * 5 ,因此我们只需要关注阶乘中有多少对 25 乘积。

在阶乘 n! = n * (n - 1) * ... * 1 中,因子 2 的数量总是比因子 5 的数量多,因为每个偶数都会贡献一个 2。因此,尾随零的数量由因子 5 的数量决定 。换句话说,阶乘中有多少个 5,就有多少个尾随零。

直接计算阶乘导致整数溢出,解答错误:

cpp 复制代码
class Solution {
public:
    int trailingZeroes(int n) {
        if(n==0) return 0;
        long long ans=1;
        for(int i=n;i>0;i--){
            ans *=i;
        }
        int f=0;
        while(ans%10==0){
            f++;
            ans/=10;
        }
        return f;
    }
};

计算阶乘时,数值迅速变得非常大,超出了 long long 类型可以存储的范围。为了避免溢出问题,并不需要实际计算阶乘本身。可以通过直接统计 n! 中有多少个因子 5 来解决问题。

相关推荐
IT猿手1 小时前
基于强化学习 Q-learning 算法求解城市场景下无人机三维路径规划研究,提供完整MATLAB代码
神经网络·算法·matlab·人机交互·无人机·强化学习·无人机三维路径规划
万能程序员-传康Kk5 小时前
旅游推荐数据分析可视化系统算法
算法·数据分析·旅游
PXM的算法星球5 小时前
【并发编程基石】CAS无锁算法详解:原理、实现与应用场景
算法
ll7788115 小时前
C++学习之路,从0到精通的征途:继承
开发语言·数据结构·c++·学习·算法
烨然若神人~5 小时前
算法第十七天|654. 最大二叉树、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树
算法
爱coding的橙子5 小时前
每日算法刷题Day2 5.10:leetcode数组1道题3种解法,用时40min
算法·leetcode
Akiiiira5 小时前
【数据结构】栈
数据结构
阳洞洞5 小时前
leetcode 18. 四数之和
leetcode·双指针
程序媛小盐6 小时前
贪心算法:最小生成树
算法·贪心算法·图论
Panesle6 小时前
分布式异步强化学习框架训练32B大模型:INTELLECT-2
人工智能·分布式·深度学习·算法·大模型