Leetcode--172. 阶乘后的零
初始化sum为0。 进入一个循环,条件为n >= 5。 在每次循环中,将sum加上n除以5的商,然后将n更新为n除以5的结果。 当n小于5时,循环结束。 初始化sum:将sum初始化为0,用于记录末尾零的数量。 循环处理:使用while循环,当n大于等于5时继续执行。 返回结果:当循环结束时,sum即为n!末尾零的数量。
发布日期:2021-04-30 21:00:36
浏览次数:139
分类:精选文章
本文共 592 字,大约阅读时间需要 1 分钟。
给定一个整数n,计算n!(n的阶乘)末尾零的数量。这个问题可以通过分析因数分解来解决。
阶乘末尾的零的数量取决于因数10的数量,而10是由2和5相乘得到的。由于2的数量通常比5多,因此末尾零的数量由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 += n / 5:将当前n除以5的商加到sum中,表示这部分因数5贡献的末尾零数量。
- n = n / 5:将n更新为n除以5的结果,继续处理更高的幂次(如25、125等)。
这个实现简洁高效,能够在O(log n)的时间内解决问题。
发表评论
最新留言
网站不错 人气很旺了 加油
[***.192.178.218]2026年06月02日 02时06分43秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
php机器人聊天对话框,基于AIML的PHP聊天机器人
2023-03-01
PHP查找数组中最大值与最小值
2023-03-01
php查最大值,在PHP数组中查找最大值
2023-03-01
php根据年月日计算年龄
2023-03-01
RabbitMQ - 单机部署(超详细)
2023-03-01
php检查注册,PHP检查注册的电子邮件地址是一个’school.edu’地址
2023-03-01
php模拟发送GET和POST请求
2023-03-01
RabbitMQ - 以 MQ 为例,手写一个 RPC 框架 demo
2023-03-01
php模板引擎smarty
2023-03-01
php正则表达式模式
2023-03-01
php正则表达式的特殊字符含义
2023-03-01
PHP正则表达式获取武汉市的实时pm2.5数据并邮件发送phpmailer
2023-03-01
RabbitMQ + JMeter组合,优化你的中间件处理方式!
2023-03-01
PHP水仙花问题解法之一
2023-03-01
php没有解析是怎么回事,linux下php文件没有被剖析怎么办?_后端开发
2023-03-01
php注册页面实现注册后跳转页面
2023-03-01
PHP消息队列的实现方式与详解,值得一看
2023-03-01
PHP混合Go协程并发
2023-03-01
php源码中如何添加滚动公告,给WordPress网站添加滚动公告的方法
2023-03-01