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

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

时间:2016-06-24 15:38:00      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:

题目:输入两个整数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;
}


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

标签:

原文地址:http://blog.csdn.net/zhou753099943/article/details/51737145

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