如何求N的阶乘所得的数字末尾含有多少个0

原题是这样:  

给定一个整数N ,那么N 的阶乘N !末尾有多少个0呢?例如:N =10,N !=3 628 800,N !的末尾有两个0。

初看这样的题目可能会想到直接求出N!的阶乘,然后再计算出0的个数。显然用这种方法如果N很大的情况下,非常容易溢出。所以我们可以换个角度来分析这个问题。

N!=1×2×3×4×5×6×··· ×N

我们可以对N!进行分解质因数

N!=2x ×3y ×5z ··········

可以看到2和5相乘必然会产生一个10,而这个10会在阶乘的末尾添加一个0。那么问题就转化为2x ×5z 可以产生多少个0,即min(x,z),显然X肯定大于Z(能被2整除的数肯定比5多),最终问题转化为求Z的值-即找出1...N能分解出多少个5, 程序如下:

 

  1. int countFactorialZero(int N) {   
  2.     int ret = 0, i, j;   
  3.     for(i = 1; i <= N; i++)   
  4.     {   
  5.         j = i;   
  6.         while(j % 5 ==0)   
  7.        {   
  8.            ret++;   
  9.            j /= 5;   
  10.        }   
  11.     }   
  12.     return ret;   
  13. }  

int countFactorialZero(int N) { int ret = 0, i, j; for(i = 1; i <= N; i++) { j = i; while(j % 5 ==0) { ret++; j /= 5; } } return ret; }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值