面试宝典(PART I)位运算(I)求X和Y的平均数

使用位运算实现取平均数

实例代码
#include <cstdio>

using namespace std;
int func(int x,int );

int main()
{
    printf("result=%d",func(729,271));
    return 0;
}
int func(int x,int y){

    return (x&y)+((x^y)>>1);
}
输出结果:

这里写图片描述
可以看到这里的结果就是,两个数的平均数

结果分析:

这个函数可以分为两个部分

一是x&y

这里是按位与,可以理解为相同则保持原状,不同则为0.
这里写图片描述
很明显这里保存了X和Y相同位置的和的一半。

二是x^y

这里是按位异或,可以相同则为0,不同则为1.
这里写图片描述
好了,这里也很明显,是不同位的和,注意这里不是一半。

三是(x^y)>>1

右移一位,代表值为原来的一半。

四是(x&y)+((x^y)>>1)

者代表了相同位和的一半加上不同位置的和的一半,结果就是原来的两个数的和的一半,就是二者的平均数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值