输入两个整数m和n,计算m需要改变多少位才能得到n

题目:输入两个整数m和n,计算m需要改变多少位才能得到n?

解析:

        这个题我最开始是没有思路的,想了很久才有点思路,思路的来源是把他们转化成二进制后才有的

       例如:(5)的二进制:0101  (3)的二进制:0011
       如果要把5变成3的话,需要改变:2次,因为第一位0和最后一位1都相同

        所以不需要改变,做法,先将两个数异或,然后求异或后1的个数

int GetCount(int N,int M)  
{  
    int value=N^M;//先将两个数异或  
    int count=0;  
    while(value)  
    {  
        count++;  
        value=(value&(value-1));//求异或后1的个数  
    }  
    return count;  
}  
  
void TestGetCount()  
{  
    int n=5;  //0101  
    int m=3; //1010  
    //题目的意思本意是将:1010-->0101  
    cout<<"count is :"<<GetCount(n,m)<<endl;  
}  
转自:http://blog.csdn.net/zhou753099943/article/details/51737145

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值