末尾0的个数

输入一个正整数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;
	}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值