Factorial Trailing Zeroes
来源:互联网 发布:淘宝门头制作 编辑:程序博客网 时间:2024/05/16 06:46
问题:
Given an integer n, return the number of trailing zeroes in n!.Given an integer n, return the number of trailing zeroes in n!.
Note: Your solution should be in logarithmic time complexity.
代码:
#include <iostream>
#include <math.h>
#include <vector>
using namespace std;
class Solution {
public:
int trailingZeroes(int n) {
int retCnt=0,tmp5=5;
while(tmp5<=n){
// cout<<tmp5<<" "<<n<<endl;
retCnt+=n/tmp5;
tmp5*=5;
if(tmp5%5!=0) break;
}
return retCnt;
}
};
解析:
问题是给定整数n,返回n!中的尾随零数。
能够构成末尾0,其实决定因素在于1 to n 的数一共有多少个5因子。那么我们这样考虑:
对于5
那么能够被他整除的是 5 10 15 25 30 ...
这样其实便一共有n/5,对于 25 50 这样的数包括了两个5因子,我们在后面会计算的,在考虑5的时候,结果便是 n/5。对于25
能够被整除的是 25 50 75 ...
这样,其实一共有n/25个,这时候25 中的两个5因子,变都计数了。
对于 125
同样能够被其整除的是125 625...
这样,是不是结果其实便是:
n/5 + n/25 + n/125 ...
0 0
- Factorial Trailing Zeroes
- Factorial Trailing Zeroes
- Factorial Trailing Zeroes
- Factorial Trailing Zeroes
- [leetcode]Factorial Trailing Zeroes
- [LeetCode] Factorial Trailing Zeroes
- Leetcode Factorial Trailing Zeroes
- Leetcode: Factorial Trailing Zeroes
- 【Leetcode】Factorial Trailing Zeroes
- Factorial Trailing Zeroes
- leetcode:Factorial Trailing Zeroes
- Java-Factorial Trailing Zeroes
- Factorial Trailing Zeroes (Java)
- Factorial Trailing Zeroes
- Leetcode: Factorial Trailing Zeroes
- Leetcode: Factorial Trailing Zeroes
- Factorial Trailing Zeroes
- Factorial Trailing Zeroes
- 获取所有下级的id
- bzoj1491: [NOI2007]社交网络
- 机器学习 逻辑回归
- 用python下载指定页面静态图片
- 对象指针
- Factorial Trailing Zeroes
- 利用输入法输入汉字,如何统计字数
- Java事务处理全解析(八)——分布式事务入门例子(Spring+JTA+Atomikos+Hibernate+JMS)
- Android 开发环境配置
- Hibernate之一对多与多对一映射
- centos7安装php7
- 机器学习—随机森林算法
- 博客迁移至简书
- Http协议学习