Java如何计算一个数的阶乘末尾有多少个零?

news2024/9/20 14:28:05

文章有点长,请耐心看完~~~

这个问题涉及到阶乘(factorial)的一个有趣特性,即阶乘结果末尾零的数量。要理解这一点,我们首先要知道什么情况下一个数的末尾会产生零。

什么情况下一个数的末尾会产生零

在十进制数制中,一个数的末尾要有零,那么这个数必须能被10整除。而10是由2和5相乘得到的(10=2×5)。因此,为了在一个数中找到末尾的零,我们需要找到这个数中因子2和因子5的对数(也就是找到这个数里一共有多少对2×5)。

末尾0的个数由因子2还是因子5决定

在阶乘中,因子2的数量(只要是2的倍数就有因子2)总是远多于因子5的数量(5的倍数显然跨度更大,比2少)。因此,当我们计算一个数的阶乘时,末尾零的数量主要由该数中因子5的数量决定(就像一个木桶能装多少水由最矮的那块木板决定,就算你有再多的2,但是就那么几个5,也只有几个2×5,比如你有5个2,3个5,那只有3对2×5)。每当我们在阶乘中遇到一个5的倍数时,我们就可以至少增加一个末尾的零。如果这个5的倍数还包含额外的因子5(比如25, 125等),那么它就可以贡献更多的零。

如何计算因子5的个数

这个观察结果允许我们使用一个更高效的算法来计算阶乘末尾零的数量,而不需要真正去计算整个阶乘的值。这个算法就是不断地将给定的数除以5,并累加每次除法的结果。因为每次除以5,我们实际上是在找出这个数可以分解为多少个5的因子(包括5的幂次)。

例如,对于数字100,我们可以这样计算阶乘末尾零的数量:

  • 100除以5等于20,说明有20个数是5的倍数,贡献20个因子5。
  • 但是,这20个数中有些还包含额外的因子5。我们将20除以5得到4,说明有4个数(25, 50, 75, 100)是5的平方的倍数,额外贡献4个因子5。
  • 如果需要,我们可以继续这个过程,但在这个例子中,100以内没有5的三次方的倍数。

所以,100的阶乘末尾有20+4=24个零。但是,对于大多数实际应用来说,只进行第一次除法(即除以5)就足够了,因为更高次幂的5非常罕见。

验证一下20的阶乘末尾0的个数是不是20/5=4,如下

代码表示如下

public int trailingZeroes(int n) {  
        int count = 0;  
        while (n > 0) {  
            n /= 5; // 每次除以5,找到所有的5的倍数  
            count += n; // 将找到的5的倍数数量加到count上  
        }  
        return count;  
    }  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2103840.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

代码随想录训练营day35|46. 携带研究材料,416. 分割等和子集

46. 携带研究材料 思路:用一个数组来记录?dp[i]带i件物品的最大价值 好吧,这里用的是一个二维数组dp[i][j],表示从[0,i]的物间任选武平,能用容量为j的背包装下的最大价值 重量 价值 物品0 1 15 物品1 3 2…

AI绘画|Stable Diffusion高质量提示词收集(附提示词手册以及提示词插件)

使用平台:comfyui 模型:AlbedoBase-XL 图片尺寸:768x1280 提示词万字手册,可以扫描下方,免费获取 图1 提示词 an attractive rough cyborg woman with a serious look in her eyes, messy conceptual felt-tip pen (drawing:1.3) by (Yoji Shinkawa:…

“三年级英语”暴增5亿搜索量?需求来了!附2个极品AI吸粉玩法!

家人们!在英语细分领域,一直都是付费知识中的风口黄金大赛道。 而这两天“英语”这个关键词,在微信指数上的日搜索量突然猛增到5个亿。 这两天全网热词“三年级英语”,日环比搜索指数更是486.2%增长率,一天时间内就增…

vsftpd的安装和配置

目录 vsftpd的下载与配置 下载vsftpd vsftpd的配置 测试服务的功能 vsftpd的下载与配置 下载vsftpd rpm -qc vsftpd,检查vsftpd安装包是否存在,存在则不需要安装。 yum install -y vsftpd,不存在则yum安装vsftpd。 安装成功 vsftpd的…

早上醒来嗓子干、喉咙痛、咳嗽……快用这个润养好物,给嗓子做个spa,让身体润起来~

进入秋季,很多人出现了眼睛干涩、大便干燥、嘴唇干裂、咽喉疼痛等症状,虽说这些还能够忍受,但它却影响了正常的饮食和休息。 秋季气候干燥,外界燥邪侵犯肺部,易伤津液,肺失滋润,清肃失司&#x…

宣布 Vue 3.5 版发布

宣布 Vue 3.5 版发布 今天我们很高兴地宣布 Vue 3.5 版“天元突破红莲螺岩”正式发布! 这一小版本发布没有破坏性更改,包括内部改进和一些有用的新特性。我们将在这篇博客中介绍一些亮点 - 详细的更改和新特性请查阅 GitHub 上的完整变更日志。 响应式…

单片机上搭配的SPI NOR FLASH容量告急!扩容新选择

文章目录 前言:正文: 为便于理解并省去容量单位转换的麻烦,以下容量单位均使用Byte单位(128Mbit16MByte) 前言: NOR FLASH 是市场上两种主要的非易失闪存技术之一。Intel于1988年首先开发出NOR Flash 技术…

代码审计总结

代码审计总结 概述 一、代码审计 1.1什么是代码审计? 1.2为什么要执行代码审核? 1.3代码审计的好处 二、代码审计流程 2.1代码检查方法 2.2代码检查项目 2.3编码规范 2.4代码检查规范 2.5缺陷检查表 2.6代码审计复查 2.7代码审计结果总结 三…

由一个 SwiftData “诡异”运行时崩溃而引发的钩深索隐(一)

概述 从 WWDC 23 开始,苹果推出了全新的数据库框架 SwiftData。它借助于 Swift 语言简洁而富有表现力的特点,抛弃了以往数据库所有的额外配置文件,只靠纯代码描述就可以干脆利索的让数据库的创建和增删改查(CRUD)一气…

10分钟了解OPPO中间件容器化实践

背景 OPPO是一家全球化的科技公司,随着公司的快速发展,业务方向越来越多,对中间件的依赖也越来越紧密,中间件的集群的数量成倍数增长,在中间件的部署,使用,以及运维出现各种问题。 1.中间件与业…

CAD图纸防泄密有哪些方法?五个防泄密方法分享

CAD图纸作为工程设计的重要资料,其防泄密工作至关重要。以下将分享五个有效的CAD图纸防泄密方法,旨在确保图纸的安全性和机密性。 1. 使用CAD软件自带的加密功能 大多数CAD软件,如AutoCAD,都内置了加密功能。在保存CAD图纸时&am…

MySQL主从复制(Linux篇)

1.概述 MySQL的主从复制(Master-Slave Replication)是一种数据复制解决方案,将主数据库的DDL和DML操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(也叫重做),从而是的从库…

MES系统:现代工厂生产车间的科技与管理创新

一、现代工厂生产车间:高度集成、自动化与智能化 在当今这个日新月异的工业时代,工厂生产车间已经远远超越了传统意义上的简单生产线概念,它们正逐步演变为一个高度集成、自动化与智能化的生态系统。这一变革不仅极大地提升了生产效率&#…

实战项目:俄罗斯方块(七)

文章目录 🍊自我介绍🍊图形存储及输出设置类型设计图形输出代码设计要实现的结果展示user_global.c(全局变量的C文件)user_print.huser_print.cmain.c 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞关注评论收藏(一…

股指期货与股指期权为什么是熊市中的风险管理利器?

在如今波动剧烈的熊市环境中,期货市场的多空双边机制和T0的交易制度显得尤为灵活和必要。对于投资者而言,利用期货市场对冲股票现货风险成为了一种重要的策略。在期货市场中,股指期货、股指期权以及股票期权是三大得力工具,它们为…

Windows下安装ELK8(elasticsearch、logstash、kibana)及相关工具插件

目录 概述 ELK简介 安装elasticsearch 下载elasticsearch 解压 配置不用登录及关闭SSL 启动elasticsearch 访问elasticsearch 安装elasticsearch-head 提前准备node.js 下载elasticsearch-head 解压 浏览器打开index.html 安装kibana 下载kibana 解压 运行kib…

渠道招商经理岗位职责和任职要求?

渠道经理,作为企业与投资者之间的沟通桥梁,角色是非常重要。 作为一名手工酸奶品牌的创始人,我一直扮演渠道招商经理的角色,我来为大家分享职责和任职要求! 一、渠道经理的职责! 1、渠道开发 负责公司渠…

Vue3+TypeScript+Vite集成mars3d.layer.WeiVectorTileLayer加载本地shp文件

前景提要,在新建的vite项目中,想要实现mars3d的矢量瓦片方式加载geojson数据。加载本地shp文件。 代码说明: 1.在项目中集成mars3d后,构造map后开始在map上增加读取数据的操作: mars3d.Util.fetchJson({ url: "…

Git学习尚硅谷(003 git分支操作)

尚硅谷Git入门到精通全套教程(涵盖GitHub\Gitee码云\GitLab) 总时长 4:52:00 共45P 此文章包含第15p-第p18的内容 文章目录 git分支操作分支介绍分支的好处 分支的操作查看分支创建分支切换分支&修改分支合并分支正常合并分支冲突合并 git分支操作…

10,sql约束(2)

MySQL中primary key和unique的区别 在sql、oracle中的constrain有两种约束,都是对列的唯一性限制:unique与primary key,它们的区别如下: 1、unique key要求列唯一,但不包括Null字段,也就是约束的列可以为空…