当前位置: 首页 > news >正文

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,正好对齐"

http://www.cnnetsun.cn/news/107477.html

相关文章:

  • ScriptHookV模组开发实战:从入门到精通的完整指南
  • 重磅!AI应用架构师力推的企业虚拟运营方案_副本
  • pose-search:人体动作分析与姿态搜索终极指南
  • 终极隐私保护方案:用Buzz实现完全离线的语音转文字
  • DTLN实时降噪技术:用AI算法打造纯净语音体验的完整指南
  • 移动端视频录制技术革新:基于MediaRecorder的高性能解决方案
  • EmotiVoice与RVC的区别是什么?一文讲清两者定位差异
  • EmotiVoice语音合成中断怎么办?常见错误排查
  • ComfyUI-SeedVR2视频超分插件完整安装与配置指南
  • 开源TTS新星崛起:EmotiVoice为何备受开发者青睐?
  • 记录Kibana多实例竞争导致的迁移锁
  • PySlowFast混合精度训练终极技巧:快速突破视频模型性能瓶颈的完整解决方案
  • 多肽合成丨HNGS14G CAS号: 330936-70-4
  • 43、Linux 网络安全:防火墙与认证机制深度解析(上)
  • 44、一次性密码与安全外壳:保障系统安全登录的有效手段
  • PostgreSQL pgvector扩展:向量相似性搜索的终极实践指南
  • 50、Linux系统安装与磁盘分区全攻略
  • 27、Linux 路由软件配置指南
  • KISS FFT轻量级信号处理终极指南:从入门到精通
  • 快速掌握X-AnyLabeling:GeCO模型在目标计数中的完整实践指南
  • Mac M1芯片运行EmotiVoice性能表现如何?
  • 如何快速构建Next.js多租户认证系统:终极完整指南
  • 计算机Java毕设实战-基于JAVA的北京市公交管理系统基于Java的城市公交查询管理系统的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 计算机Java毕设实战-基于SpringBoot的景点门票销售管理系统基于JAVA白云山景点门票销售管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 价值投资中的智能化精准癌症治疗系统分析
  • 前端一把梭,后端火葬场:别再让你的 Node.js 服务“裸奔”了
  • NVIDIA显卡配置实用手册:从日常应用到专业调校
  • 30、Shell脚本编写与Bash安装指南
  • 31、Bash使用与相关Shell比较全解析
  • 33、Bash 环境变量、操作符及选项全解析