输入一个正整数n,求n!(即阶乘)末尾有多少个0? 比如: n = 10; n! = 3628800,所以答案为2
输入描述:
输入为一行,n(1 ≤ n ≤ 1000)
输出描述:
输出一个整数,即题目所求
示例1
输入
10
输出
2
链接:https://www.nowcoder.com/questionTerminal/6ffdd7e4197c403e88c6a8aa3e7a332a
来源:牛客网
解题思路:0来自于 2 × 5,在2的数量足够多的前提下,末尾0的个数取决于5的个数。 在任意n(n >= 5)的阶乘中,2的个数绝对多于5。所以此题可以转换为,求n的阶乘中5的个数。
public class TheNumberOfEndZeros {
public static int getNumber_1(int n) {
int res = 0, tmp;
for (int i = n; i >= 5; i --) {
tmp = i;
while (tmp % 5 == 0) {
res++;
tmp /= 5;
}
}
return res;
}
public static int getNumber_2(int n) {
int res = 0, tmp;
//将n递减为5的倍数
while (n % 5 != 0) {
n--;
}
//此时n为5的倍数,可以减少循环次数,在某种程度上算是解法1的小优化。
for (int i = n; i >= 5; i -= 5) {
tmp = i;
while (tmp % 5 == 0) {
res++;
tmp /= 5;
}
}
return res;
}
/**此解法比较鬼,真的很难想到。可以在掌握前两种解法的前提下拓宽一下知识面哈哈~
* @param n
* @return
*/
public static int getNumber_3(int n) {
int res = 0;
while(n >= 5) {
res += n / 5;
n /= 5;
}
return res;
}
}