求N!中末尾有多少个0

分析:

对N进行质因数分解 N=2^x * 3^y * 5^z...,由于10 = 2*5,所以末尾0的个数只和x与z有关,每一对2和5相乘可以得到一个10,于是末尾0的个数=min(x,z)。在实际中x是远远大于z的,所以我们只要求出z的值即可。
  根据公式
  z = N/5 + N/5^2 + N/5^3+...+N/5^k
  这表明,5的倍数贡献了一个5,5^2的倍数又贡献了一个5...。
  比如:25其实是贡献了2个5,但是在N/5中已经贡献了一个,所以在N/5^2中再贡献一个;同样,125在N/5中贡献一个,在N/5^2中贡献一个,在N/5^3中再贡献一个,一共是3个。


代码:

	public int getContinueZero(int num){
		int countOfZero = 0;
		while(num>0)
		{
			countOfZero+=num/5;
			num/=5;
		}
		return countOfZero;
	}

用同样思路解下一题:

求N!的二进制中最低位1的位置。实际上就是判断二进制末尾有多少个0,然后位置=0的个数+1;

判断二进制末尾0的个数可以用右移操作来完成。而二进制每次右移一位相当于十进制除以2,直到除不够为止。所以归根结底就是要求N!质因数分解的2的个数x。这个操作与上面求5的个数如出一辙。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值