项目github地址:bitcarmanlee easy-algorithm-interview-and-practice
欢迎大家star,留言,一起学习进步
本博主曾被问过这样一个问题:求n的阶乘中末尾含有多少个0。例如n=10,n!=3628800,那么n!末尾有两个0。
直接计算n!的值显然不合适,因为n!数值太大,很容易溢出。而且这种无脑的计算方式,显然不适合面试的时候装nbility拿高薪offer。
1解法一:分解质因数
本博主当时被问这个问题的时候的第一反应就是:要相乘产生0,那肯定是与5相乘的结果。对n!如果分解质因数的话,结果为0的个数只与2与5的个数有关,每一次2*5就能产生一个0。因为2的个数肯定要大于5的个数,所以只要关注5的个数就可以了。
2解法二:解法一的升级版
r e t = n / 5 + n / 5 2 + n / 5 3 + ⋯ ret = n/5 + n/5^2 + n/5^3 +\cdots ret=n/5+n/52+n/53+⋯
思路讲完了,按照我们的惯例:
talk is cheap, show me the code:
#!/usr/bin/env python
#coding:utf-8
'''
@author: lei.wang
'''
def fact_first(n):
ret = 0
for i in xrange(n+1):
j = i
while (j%5 == 0 and j > 0): #注意要加上j>0,否则会死循环
ret += 1
j /= 5
return ret
def fact_second(n):
ret = 0
while (n):
ret += n/5
n /= 5
return ret
if __name__ == '__main__':
ret_one = fact_first(100)
print "ret_one is: ",ret_one
ret_sec = fact_second(100)
print "ret_sec is: ",ret_sec
运行结果
ret_one is: 24
ret_sec is: 24