网站首页 > 技术文章 正文
关注“爱当程序员的我”,每天都有关于编程头条发布
今天给大家讲讲神奇的位运算,有些想法总是那么的出人意料。
不用额外的变量交换两个整数的值
这题采用异或位运算,异或的原理是相同位置的二进制值异或,相同结果为0,不同结果为1。
两个相同的数异或结果等于0。
就这道题而言,在运算过程中会产生一个中间值,即a与b的异或结果,a异或b再异或b就会等于a,如果第二次异或a就会等于b。
演示
所以直接三个异或就可以搞定
C++代码实现
不用任何比较判断两个数中大的那个数
我们将两个数做差,得到另一个数,判断这个数的符号位就可以了。当然,不能直接使用判断语句,所以我们使用位运算来操作。
C++代码实现
整数的二进制中有多少个1
每次循环采用n&=(n-1),这样可以跳过二进制位是0的数。
演示
C++代码实现
数组中只有一个数出现了奇数次,其他数都出现偶数次,找出这个数
这道题还是使用了异或的性质,两个相同的数异或等于0,遍历一遍数组就可以得到出现奇数次的那个数。
C++代码实现
结束语:
如果喜欢这篇头条,一定要收藏哟^O^
点击关注,了解更多关于编程的知识^O^
如果有不懂的地方,可以留言,相互探讨,相互学习,共同进步^O^
- 上一篇: 关于C语言中的操作符你知道多少?(一)
- 下一篇: C、C++高性能编码指南(高质量c c++编程)
猜你喜欢
- 2024-10-18 了解C语言中的操作符(c语言操作符怎么定义)
- 2024-10-18 20天轻松入门《C++第二章——程序设计基础》—3经坛教育
- 2024-10-18 C++中的volatile关键字(volatile关键字 c语言)
- 2024-10-18 C/C++软件开发证书怎么考?报考难度大吗?含金量高吗?
- 2024-10-18 c++数据类型(c++数据类型转换)
- 2024-10-18 C语言中实现边沿函数算法及应用,这是抛弃PLC留下的痛!
- 2024-10-18 C基础、经典问题:交换a、b值较好的方法?
- 2024-10-18 C++ 避免使用模块重新编译模板库(调用c++模块,不忽略异常)
- 2024-10-18 面试大厂c/c++后台开发岗,如何从技术层面上杀出重围?
- 2024-10-18 关于C语言交换两个数的实现方法以及个人心得
- 最近发表
- 标签列表
-
- cmd/c (64)
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- sqlset (64)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)