(没明白)程序员面试宝典(p39)-----(x&y) + ( (x^y)>>1 )证明


转载:http://blog.youkuaiyun.com/leo115/article/details/7993110

对于位运算求两个数的平均值问题,(整形数据)
int  average(int x,int y)
{
return ( (x&y) + ( (x^y)>>1 ) );
}
给出两个整数,求出结果。
刚开始看到这道题的做法就是x和y转换为二进制,然后计算出结果。在没有办法的情况下这样做也可以得出结果。

跟你想象的一点不差,这里确实有捷径。

题目中的&和^都是位运算,所以我们有必要研究数据的对位情况。任何数据只有3中情况。
1) 0 与 0对应
2) 0 与 1对应
3)1 与 1对应
那么它们分别什么诀窍呢?
举例子来说:0101 和1101 也就是x和y分别为5、13.这两个数据出现了所谓的3种对应位情况。
我们可以把数据拆开来看: 5=0000+100+00+1
13=1000+100+00+1
他们分为为第一位,第二位,.....

当0和1对应时,x&y结果为0, x^y的结果呢?是不是就是x和y中那个对应位不为0的数据。
例如:上面数据的第四位0和1对位。此时x^y的结果就是1000.正是1101的第四位结果。
再右移一位,相当于除以2,所以当 0和1对位是原函数结果为 (x+y)/2;

在看1和1对应,1^1的结果为0,所以原函数后半部分不考虑,1&1结果为1,这也是(x+y)/2;
例如:第一位和第三位的对位,都为100,他们相与的结果和相加除以2相等,即x&y=(x+y)/2;

0与0对应的时候,无论怎么样都是0,即也符合(x+y)/2.

综合上述三种情况,我们可以知道其实原函数返回就是(x+y)/2。
可改写为:
return (x+y)/2;

这是程序员面试宝典中的一道题,我认为作者在书中的解释 (x&y)为x和y相同位的一半,这该怎么理解呢?我觉得这是一个错误解释。希望大家读书能有明辨的能力。

### 黑马程序员面试宝典 2023 PDF 下载或内容概要 关于黑马程序员的《面试宝典》系列书籍,其主要目标是帮助开发者准备技术面试,尤其是针对一线互联网公司的岗位需求。虽然目前有明确提到具体的“2023版PDF下载链接”,但从以往版本的内容来看,这类资料通常涵盖了多个热门编程领域和技术栈的知识点[^1]。 #### 内容概要 以下是基于过往版本推测可能包含的核心主题: 1. **基础技能** - 数据结构与算法分析:数组、链表、堆栈、队列、树、图以及常见排序和查找算法。 - 计算机网络原理:TCP/IP协议族详解、HTTP/HTTPS工作流程、DNS解析机制等。 - 操作系统概念:进程线程管理、内存分配策略、文件I/O操作及时序同步问题。 2. **主流开发语言深入探讨** - Python核心技术要点及其应用场景介绍。 ```python # 示例代码展示闭包特性 def outer_function(x): def inner_function(y): return x + y return inner_function closure_example = outer_function(5) result = closure_example(3) # 结果应为8 print(result) ``` - Java虚拟机(JVM)内部运行机制剖析;Spring框架生态体系概述。 3. **前端框架精讲** - Vue.js全家桶全面解读——组件化开发模式实践指南[^2]。 * vue-cli工具初始化项目配置方法; * Vuex状态管理模式运用技巧; * vue-router路由切换逻辑实现细节。 - React生态系统入门至精通路径规划建议。 4. **数据库理论联系实际** - SQL查询优化原则分享;NoSQL存储解决方案对比研究。 5. **云计算平台服务选型指导** - AWS/Azure/GCP三大公有云服务商功能特点归纳整理。 6. **分布式架构设计思路探索** - 微服务拆分标准确立依据;容器编排Kubernetes基本命令熟悉程度检测。 7. **安全防护意识培养** - 常见Web攻击手段防范措施列举说明;加密解密算法选用场景讨论。 如果需要获取具体电子书形式的学习材料,则可以通过正规渠道购买正版图书或者访问官方网站查看是否有免费样章提供阅读体验机会。同时也可以关注相关在线教育平台推出的配套视频课程作为辅助学习资源补充。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值