简单问题与算法-阶乘尾数零的个数

 100!的末尾有多少个零?

1.问题分析与算法设计

 可以设想:先求出100!的值,然后数一下末尾有多少个零。事实上,与“高次方数的尾数”一样,由于计算机所能表示的整数范围有限,这是不可能的。

 为了解决这个问题,必须首先从数学上分析在100!结果值得末尾产生零的条件。不难看出:一个整数若含有一个因子5则必然会在求100!时产生一个零。因此问题转化为求1到100这100个整数中包含了多少个因子5。若整数N能被25整除,则N包含2个因子5;若整数N能被5整除,则N包含了一个因子5。

 

2.程序说明与注释

#include <stdio.h>

 

void main()

{

 int a,count = 0;

 

 for(a=5;a<=100;a+=5) //循环从5开始,以5的倍数为步长,考察整数

 {

  count++; //若为5的倍数,计数器+1

  

  if(!(a%25))

  {

   count++; //若为25的倍数,则计数器再+1

  }

 }

 

 printf("The number of 0 in the end of 100! is:%d.\n",count);//打印结果

}

 

3.运行结果

 

24

 

4.问题的进一步讨论

 

本题的求解程序是正确的,但存在明显的缺点。程序中判断整数N包含多少个因子5的方法是与题目中100有关的,若题目中的100改为1000,则就要修改程序中因子5的数目的算法了。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值