码迷,mamicode.com
首页 > 其他好文 > 详细

编程之美2——N!的二进制表示中最低位1的位置

时间:2015-04-11 11:56:30      阅读:105      评论:0      收藏:0      [点我收藏+]

标签:编程之美

    任何数在计算机内部都是用二进制表示的,可以用这个特性来快速判断N!的二进制表示中最低位1的位置。


解法一:

将一个数的二进制数除以2,若二进制数的末尾是0,则能整除,否则不能整除。

因此,求 N!的二进制表示中最低位1的位置 即为求 N!中有多少个质因数2


以下为代码1:

#include <iostream>
using namespace std;
int main(void)
{


	int n,m;
	m=0;
	cin>>n;
	while(n)
	{
		n>>=1;
		m+=n;
	}
	cout<< m+1 <<endl;    //m为n!中质因数2的个数,所以最后结果要加 1
	return 0;
}


解法二:

N!中含有质因数2的个数,等于 n-(n的二进制表示中1的个数)

(这个规律可自行证明)


代码2:

#include <iostream>
using namespace std;
int main(void)
{
    int n,i,j,m;
    m=0;
    j=0x1;
    cin>>n;
    i=n;
    while(i)
    {
	m+=(i&j);
	i>>=1;
    }
    cout << n-m+1 <<endl;    //m为n!中质因数2的个数,所以最后结果要加 1
    return 0;
}


本文出自 “hacker” 博客,请务必保留此出处http://anglecode.blog.51cto.com/5628271/1631147

编程之美2——N!的二进制表示中最低位1的位置

标签:编程之美

原文地址:http://anglecode.blog.51cto.com/5628271/1631147

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!