Cracking the coding interview--Q19.3
来源:互联网 发布:财务流程优化 编辑:程序博客网 时间:2024/05/16 11:11
题目
原文:
Write an algorithm which computes the number of trailing zeros in n factorial.
译文:
写一个算法计算n的阶乘的尾数的零的个数。
解答
首先,算出n的阶乘的结果再去计算末尾有多少个0这种方法是不可取的, 因为n的阶乘是一个非常大的数,分分种就会溢出。我们应当去分析, 是什么使n的阶乘结果末尾出现0。
n阶乘末尾的0来自因子5和2相乘,5*2=10。因此,我们只需要计算n的阶乘里, 有多少对5和2。注意到2出现的频率比5多,因此,我们只需要计算有多少个因子5即可。 我们可以列举一些例子,看看需要注意些什么:
5!, 包含1*5, 1个510!, 包含1*5,2*5, 2个515!, 包含1*5,2*5,3*5, 3个520!, 包含1*5,2*5,3*5,4*5, 4个525!, 包含1*5,2*5,3*5,4*5,5*5, 6个5...
给定一个n,用n除以5,得到的是从1到n中包含1个5的数的个数;然后用n除以5去更新n, 相当于把每一个包含5的数中的因子5取出来一个。然后继续同样的操作,让n除以5, 将得到此时仍包含有5的数的个数,依次类推。最后把计算出来的个数相加即可。 比如计算25的阶乘中末尾有几个0, 先用25除以5得到5,表示我们从5,10,15,20,25中各拿一个因子5出来,总共拿了5个。 更新n=25/5=5,再用n除以5得到1,表示我们从25中拿出另一个因子5, 其它的在第一次除以5后就不再包含因子5了。
代码如下:
int NumZeros(int n){ if(n < 0) return -1; int num = 0; while((n /= 5) > 0){ num += n; } return num;}
---EOF---
0 0
- Cracking the coding interview--Q19.3
- Cracking the coding interview--Q19.1
- Cracking the coding interview--Q19.2
- Cracking the coding interview--Q19.4
- Cracking the coding interview--Q19.5
- Cracking the coding interview--Q19.6
- Cracking the coding interview--Q19.7
- Cracking the coding interview--Q19.8
- Cracking the coding interview--Q19.10
- Cracking the coding interview--Q19.11
- Cracking the coding interview--Q19.10
- Cracking the Coding Interview
- 《Cracking the coding interview》
- Cracking The Coding Interview
- Cracking the coding interview
- Cracking the coding interview
- Cracking the coding interview--Q9.3
- Cracking the Coding Interview Chap1 Q1.3
- 什么是DSP? DSP、单片机MCU、嵌入式微处理器的区别
- 机械工业发展临多重挑战尚未脱离险境
- Hadoop 2.0 NameNode HA和Federation实践
- 【SAS系列】select语句——完成elseif或者switch的功能
- TabHost风格与Holo theme
- Cracking the coding interview--Q19.3
- Difference between HashMap, LinkedHashMap and TreeMap in Java
- 服装行业ERP系统有哪些基本功能?
- 详解Google-ProtoBuf中结构化数据的编码
- Openssl 漏洞POC学习
- hdu 1170 Balloon Comes!(水题)
- 黑马程序员_网络编程
- Android美工坊--底部菜单栏实现
- 学习笔记(四):Application