求N的阶乘N!中末尾0的个数
求N的阶乘N!中末尾0的个数
有道问题是这样的:给定一个正整数N,那么N的阶乘N!末尾中有多少个0呢?例如:N=10,N=3628800,则N!的末尾有两个0;直接上干货,算法思想如下:对于任意一个正整数N!,都可以化为N!= (2^X)*(3^Y)* (5^Z)......的形式,要求得末尾0的个数只需求得min(X, Z)即可,由于是求N!,则X >= Z; 即公约数5出现的频率小于等于2出现的频率,即Z=min(X, Z),即出现0的个数等于公约数5出现的次数;
方法一:
#include <stdio.h>
int main()
{
int N;
int sum = ;
scanf("%d", &N); // 输入N
for(int i = ; i <= N; i++)
{
int j = i;
while( == j % )
{
sum++; // 统计公约数5出现的频次
j /= ;
}
} printf("%d\n", sum); return ;
}
方法二:
#include <stdio.h>
int main()
{
int N;
int sum = ;
scanf("%d", &N);
while(N)
{
sum += N / ;
N /= ;
}
printf("%d\n", sum); return ;
}
求N的阶乘N!中末尾0的个数的更多相关文章
- Java 计算N阶乘末尾0的个数-LeetCode 172 Factorial Trailing Zeroes
		题目 Given an integer n, return the number of trailing zeroes in n!. Note: Your solution should be in ... 
- LightOj 1090 - Trailing Zeroes (II)---求末尾0的个数
		题目链接:http://lightoj.com/volume_showproblem.php?problem=1090 题意:给你四个数 n, r, p, q 求C(n, r) * p^q的结果中末尾 ... 
- N的阶乘末尾0的个数和其二进制表示中最后位1的位置
		问题一解法: 我们知道求N的阶乘结果末尾0的个数也就是说我们在从1做到N的乘法的时候里面产生了多少个10, 我们可以这样分解,也就是将从0到N的数分解成因式,再将这些因式相乘,那么里面有多少个 ... 
- Algorithm --> 求阶乘末尾0的个数
		求阶乘末尾0的个数 (1)给定一个整数N,那么N的阶乘N!末尾有多少个0?比如:N=10,N!=3628800,N!的末尾有2个0. (2)求N!的二进制表示中最低位为1的位置. 第一题 考虑哪些数相 ... 
- POJ 1401:Factorial 求一个数阶乘的末尾0的个数
		Factorial Time Limit: 1500MS Memory Limit: 65536K Total Submissions: 15137 Accepted: 9349 Descri ... 
- 求一个数的阶乘在 m 进制下末尾 0 的个数
		题意 : 求一个数 n 的阶层在 m 进制下末尾 0 的个数 思路分析 : 如果是 10 进制地话我们是很容易知道怎么做的,数一下其对 5 约数地个数即可,但是换成 m 进制的话就需要先将 m 分解质 ... 
- 牛客小白月赛6 水题 求n!在m进制下末尾0的个数 数论
		链接:https://www.nowcoder.com/acm/contest/135/C来源:牛客网 题目描述 其中,f(1)=1;f(2)=1;Z皇后的方案数:即在Z×Z的棋盘上放置Z个皇后,使其 ... 
- 神秘常量复出!用0x077CB531计算末尾0的个数 -- De Bruijn 序列
		http://www.matrix67.com/blog/archives/3985 神秘常量复出!用0x077CB531计算末尾0的个数 大家或许还记得 Quake III 里面的一段有如天书般的代 ... 
- 一步一步写算法(之n!中末尾零的个数统计)
		原文:一步一步写算法(之n!中末尾零的个数统计) [ 声明:版权所有,欢迎转载,请勿用于商业用途. 联系信箱:feixiaoxing @163.com] 在很多面试的题目中,求n!结果中零的个数也是 ... 
随机推荐
- 信息学奥赛(NOIP)复赛学习方法推荐
			一.确定你的语言 NOIP包括三种语言c/c++/pascal,在最初必须确定自己使用的语言.没有c/c++基础的,个人建议使用pascal,因为它更容易上手,如果有充裕的时间,则建议c/c++,因为 ... 
- jenkins将构建成功或失败的信息发送给指定URL(eg: pomelo采用jenkins持续集成)
			先提供一个思路供大家参考,想将构建成功或者失败的信息发送给指定URL的话,可以这样:1.A构建后触发另一个构建B,构建B执行某个插件2.插件的功能: (1)利用jenkins API获取构建A最 ... 
- MySQL 查看执行的SQL记录
			我们时常会有查看MySQL服务端执行的SQL记录.在MySQL5.1之后提供了支持,通过在启动时加入-l 或者--log选项即可: mysqld -l mysqld --log 在后面的版本(5.1. ... 
- Java的this和super总结
			内容: 1.this和super作用 2.继承关系图 1.this和super作用 this和super的作用: this:区分本类中的成员变量和局部变量同名的情况,代指本类 super:区分子类中的 ... 
- 框架之Tornado(简单介绍)
			引言 回想Django的部署方式 以Django为代表的python web应用部署时采用wsgi协议与服务器对接(被服务器托管),而这类服务器通常都是基于多线程的,也就是说每一个网络请求服务器都会有 ... 
- (6/24) 插件配置:轻松配置JS文件压缩
			实际开发中,在项目上线之前,我们编写的js代码是需要进行压缩的,我们可以采取压缩软件或者在线进行压缩,这不是我们的重点,在webpack中实现JS代码的压缩才是本节的核心. 通过webpack中可实现 ... 
- 《汇编语言 基于x86处理器》前五章的小程序
			▶ 书中前五章的几个小程序,基本的运算操作,使用了作者的库 Irvine32 和 Irvine64(一开始以为作者网站过期了,各网站上找到的文件大小都不一样,最后发现是要搭梯子 Orz,顺利下载).注 ... 
- wzben的QQ空间
			实习之后没有动过博客了,后续慢慢补. 
- 微信小程序注册身份证验证
			// 校验身份证号 //校验码校验 checkCode: function (val) { var p = /^[1-9]\d{5}(18|19|20)\d{2}((0[1-9])|(1[0-2])) ... 
- 文字折行不折行 css
			white-space : 1. normal 默认值 ,文字自动换行. 2. pre 使用<pre>标签形式,表示元素. * ... 
