位运算求两个数的平均值

位运算求两个数的平均值:解决的是两个数相加结果会溢出的情况;

1.先看一个代码:

位运算求两个数的平均值:

int AverageForTwoNumber(int a,int b)
{
	return ((a&b) + ((a^b) >> 1));
}

void Test()
{
	cout << AverageForTwoNumber(2,4)<< endl;  //3
	cout << AverageForTwoNumber(3,5)<< endl;  //4
}
2.解析:(无非就是两个地方 a&b和a^b):

A: a&b的作用: a和b按照位整齐排序,当a和b对应为上全为1的时候相加,那么这个位置为0,会向前进一位,所以当出现对应位全为1的时候,直接在此位保留一个1,就相当两个

对应位求平均值了。。这就相当,两个相同数字求平均值一样,两个相同数的平均值不就是本身么,2和2的平均值就是2,对应位相同为0或者为1,平均值都是本身;

B: a^b的作用:当然解决的就是和上边相反的情况,对应位相反的情况,分为a的某一个位为1,对应的b的那个位为0,或者倒过来,这个时候就要把他们异或的结果除以2,即就

是右移1位了,这又好比两个不同的数求平均值,需要加起来除2,其实异或结果就是两个数不带进位加起来的结果;最后,把两种结果加起来就行了,求平均值结束。

3.后话:其实就是把求平均值这件事分成两部分,两部分分别平均值,最后平均值相加,就是最终的平均值;

4.下面看一个图:


赐教!

posted @ 2016-07-06 20:58  云端止水  阅读(607)  评论(0编辑  收藏  举报