news 2026/4/15 21:58:53

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/4/16 9:21:58

Python实战-学生信息管理系统开发(Tkinter+Json)

本项目是一个基于Python Tkinter的图形化学生信息管理系统&#xff0c;实现学生信息的增删改查、数据保存和文件导出等功能。 这个学生信息管理系统的逻辑非常简单&#xff0c;它就像一个电子笔记本&#xff1a;所有学生信息都记在一个列表里&#xff0c;并自动保存成一个文件&…

作者头像 李华
网站建设 2026/4/16 11:04:36

导热系数测试仪厂家推荐排行榜:2025最新口碑单深度解析

在选择导热系数测试仪时&#xff0c;企业常常面临诸多困扰。比如&#xff0c;测试结果不准确&#xff0c;影响产品研发进度&#xff1b;设备稳定性差&#xff0c;频繁出现故障耽误生产&#xff1b;售后服务不及时&#xff0c;遇到问题无法快速解决。为了帮助企业快速找到靠谱的…

作者头像 李华
网站建设 2026/4/16 9:18:02

Java中Set集合的概念

java.util.Set 是 Java 集合框架的子接口&#xff0c;继承自 Collection 接口&#xff0c;核心特征是存储的元素无序且不可重复&#xff0c;不支持通过索引访问元素。 一、核心特性 1. 元素唯一性 Set 集合不允许存储重复元素&#xff0c;判断元素是否重复的依据是 equals…

作者头像 李华
网站建设 2026/4/16 11:00:29

学习Java的技巧

吃透Java的实用技巧&#xff0c;从入门到进阶不走弯路作为一门经典的面向对象编程语言&#xff0c;Java不仅是计算机专业学子的必修课&#xff0c;也是很多后端开发者的入门首选。想要学好Java&#xff0c;靠死记硬背远远不够&#xff0c;找对方法才能事半功倍。分享几个亲测有…

作者头像 李华
网站建设 2026/4/16 12:58:20

实时协作文档编辑:用Tiptap打造团队写作新体验

实时协作文档编辑&#xff1a;用Tiptap打造团队写作新体验 【免费下载链接】tiptap The headless editor framework for web artisans. 项目地址: https://gitcode.com/GitHub_Trending/ti/tiptap 在远程办公成为常态的今天&#xff0c;团队协作文档编辑不再是可有可无的…

作者头像 李华