news 2026/3/9 3:58:48

C++基础知识点——5个重要位运算技巧(通俗易懂版)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++基础知识点——5个重要位运算技巧(通俗易懂版)

前言:“1在内存中不是孤零零的1,而是前面有很多0的二进制串,具体多少个0由变量类型决定——int有31个0,long long有63个0。1的二进制:00000000,00000000,00000000,00000001”

5个位运算技巧(通俗易懂版)

技巧1:判断奇偶性 ⚖️

公式:x & 1

一句话:看最后一位是0还是1

怎么理解?

二进制就像一排灯泡(0灭1亮):

奇数的最后一位总是1: 1(1), 3(11), 5(101), 7(111) 偶数的最后一位总是0: 2(10), 4(100), 6(110), 8(1000)

代码:

if (x & 1) { cout << "奇数"; // 最后一位是1 } else { cout << "偶数"; // 最后一位是0 }

技巧2:获取二进制的某一位 🔍

公式:(x >> i) & 1

一句话:把想要的位移到最右边,然后看是0还是1

怎么理解?

比如想知道数字13(1101)的第2位:

13的二进制: 1 1 0 1 第3 第2 第1 第0位 我们要第2位:把数字右移2位 → 11(01)变成 0011 然后看最右边一位:1

代码:

int getBit(int x, int i) { return (x >> i) & 1; // 返回第i位(0或1) } // 例子:getBit(13, 2) = 1

技巧3:修改二进制的某一位 ✏️

设为1:x | (1 << i)

一句话:用一个"只有第i位是1"的数去"或"

设为0:x & ~(1 << i)

一句话:用一个"只有第i位是0"的数去"与"

怎么理解?

设为1(或运算):

x = 9(1001),想把第1位变成1 1 << 1 = 0010(只有第1位是1) 1001 | 0010 = 1011(成功!)

设为0(与运算):

x = 11(1011),想把第1位变成0 1 << 1 = 0010 ~(0010) = 1101(只有第1位是0) 1011 & 1101 = 1001(成功!)

代码:

int setBitToOne(int x, int i) { return x | (1 << i); } int setBitToZero(int x, int i) { return x & ~(1 << i); }

技巧4:判断是否为2的幂次方 ⚡

公式:(x & (x-1)) == 0

一句话:2的幂就像"1000..."(只有一个1),减1变成"0111...",一与就没了

怎么理解?

2的幂的二进制:

2^0 = 1 = 0001 2^1 = 2 = 0010 2^2 = 4 = 0100 2^3 = 8 = 1000 特点:只有一个1!

减1后:

8(1000) - 1 = 7(0111) 1000 & 0111 = 0000 ✓ 不是2的幂: 6(0110) - 1 = 5(0101) 0110 & 0101 = 0100 ≠ 0 ✗

代码

bool isPowerOfTwo(int x) { return x > 0 && (x & (x-1)) == 0; }

技巧5:获取最低位的1(lowbit)🎯

公式:x & -x

一句话:找到二进制中最右边的那个1,其他全变0

怎么理解?

x = 12(二进制1100) 最右边的1在第2位(从0开始数) -x = -12(补码表示:0100,其实是...11110100) 1100 & ...11110100 = 0100(4) 结果:0100,就是最右边那个1!

有什么用?

  • 树状数组的核心操作

  • 快速找"最右边"的1

  • 统计1的个数时可以用

代码:

int lowbit(int x) { return x & -x; } // lowbit(12) = 4 // lowbit(10) = 2(10=1010,最低位1是0010=2)

🎓 五个技巧总结

技巧公式作用记忆方法
判断奇偶x & 1看最后一位"末位1=奇数"
获取某位(x>>i) & 1看第i位"右移再看末位"
修改某位x|(1<<i)x&~(1<<i)改0或1"造面具戴面具"
2的幂判断(x&(x-1))==0判断是否只有1个1"只有一个1的消掉就没了"
最低位1x & -x找最右边的1"负数取反加1,正好对齐"

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/9 0:29:15

ScriptHookV模组开发实战:从入门到精通的完整指南

ScriptHookV模组开发实战&#xff1a;从入门到精通的完整指南 【免费下载链接】ScriptHookV An open source hook into GTAV for loading offline mods 项目地址: https://gitcode.com/gh_mirrors/sc/ScriptHookV 想要为GTA V游戏世界注入无限创意吗&#xff1f;ScriptH…

作者头像 李华
网站建设 2026/3/6 10:26:00

重磅!AI应用架构师力推的企业虚拟运营方案_副本

重磅&#xff01;AI应用架构师力推的企业虚拟运营方案关键词&#xff1a;企业虚拟运营、AI应用架构、数字孪生、智能决策系统、业务流程自动化、数据驱动运营、预测性分析摘要&#xff1a;在数字化转型的浪潮中&#xff0c;企业面临着运营成本高、决策滞后、创新速度慢等痛点。…

作者头像 李华
网站建设 2026/3/2 3:43:04

pose-search:人体动作分析与姿态搜索终极指南

pose-search&#xff1a;人体动作分析与姿态搜索终极指南 【免费下载链接】pose-search x6ud.github.io/pose-search 项目地址: https://gitcode.com/gh_mirrors/po/pose-search 在人工智能技术飞速发展的今天&#xff0c;实时姿态检测和动作搜索已成为计算机视觉领域的…

作者头像 李华
网站建设 2026/3/7 21:13:59

终极隐私保护方案:用Buzz实现完全离线的语音转文字

终极隐私保护方案&#xff1a;用Buzz实现完全离线的语音转文字 【免费下载链接】buzz Buzz transcribes and translates audio offline on your personal computer. Powered by OpenAIs Whisper. 项目地址: https://gitcode.com/gh_mirrors/buz/buzz 还在为语音转文字工…

作者头像 李华
网站建设 2026/3/7 11:57:17

DTLN实时降噪技术:用AI算法打造纯净语音体验的完整指南

DTLN实时降噪技术&#xff1a;用AI算法打造纯净语音体验的完整指南 【免费下载链接】DTLN 项目地址: https://gitcode.com/gh_mirrors/dt/DTLN 在视频会议、语音通话成为日常的今天&#xff0c;背景噪音问题困扰着无数用户。DTLN&#xff08;双信号变换LSTM网络&#x…

作者头像 李华
网站建设 2026/3/8 18:17:44

移动端视频录制技术革新:基于MediaRecorder的高性能解决方案

移动端视频录制技术革新&#xff1a;基于MediaRecorder的高性能解决方案 【免费下载链接】WeiXinRecordedDemo 仿微信视频拍摄UI, 基于ffmpeg的视频录制编辑 项目地址: https://gitcode.com/gh_mirrors/we/WeiXinRecordedDemo 问题场景&#xff1a;为什么你的视频录制总…

作者头像 李华