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

任何数在计算机内部都是用二进制表示的,可以用这个特性来快速判断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;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值