当前位置: 首页> 娱乐> 影视 > 力扣172. 阶乘后的零

力扣172. 阶乘后的零

时间:2025/9/27 10:32:29来源:https://blog.csdn.net/LNsupermali/article/details/139755728 浏览次数:0次

Problem: 172. 阶乘后的零

文章目录

  • 题目描述
  • 思路及解法
  • 复杂度
  • Code

题目描述

在这里插入图片描述

思路及解法

1.要使得末尾出现0,则乘式中必须出现因子2与5
2.而由于对于一个数的阶乘,易知因子2的个数是大于因子5的个数(因为只要出现偶数则可以分解出因子2),则关键在于寻找因子5的个数;
3.我们注意到5的倍数可以提供一个因子5, 5 × 5 = 25 5 \times 5 = 25 5×5=25的倍数可以提供两个因子5, 5 × 5 × 5 = 125 5 \times 5 \times 5 = 125 5×5×5=125可以提供三个因子5,依次类推我们每次将当前的数去求取5的倍数个数,25的倍数个数、125的倍数个数…将最终的个数相加即为最终的0的个数

复杂度

时间复杂度:

O ( l o g n ) O(logn) O(logn)

空间复杂度:

O ( 1 ) O(1) O(1)

Code

class Solution {/*** Factorial Trailing Zeroes** @param n Given number* @return int*/public int trailingZeroes(int n) {int res = 0;int divisor = 5;while (divisor <= n) {res += n / divisor;divisor *= 5;}return res;}
}
关键字:力扣172. 阶乘后的零

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: