0

0

c++中如何使用位运算_位运算技巧与高效编程实践

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-09-23 19:12:01

|

245人浏览过

|

来源于php中文网

原创

位运算通过操作二进制位提升效率,C++支持六种位运算符:&、|、^、~、,常用于判断奇偶、快速乘除2的幂、清除或提取最右1位、交换变量等,广泛应用于状态压缩、标志位管理与汉明权重计算,需注意负数移位未定义行为、符号扩展及优先级问题。

c++中如何使用位运算_位运算技巧与高效编程实践

在C++中,位运算是一种直接对整数的二进制位进行操作的技术。它不仅运行速度快,还能在某些场景下显著节省内存和提升性能。掌握位运算技巧,是写出高效代码的重要一环,尤其在算法竞赛、嵌入式开发和系统编程中非常实用。

理解基本位运算符

C++提供了六种基本的位运算符,它们作用于整数类型的每一位:

  • &:按位与。两个对应位都为1时结果才为1。
  • |:按位或。任一对应位为1时结果为1。
  • ^:按位异或。对应位不同时结果为1。
  • ~:按位取反。每一位0变1,1变0。
  • :左移。将二进制位整体向左移动n位,右边补0。
  • >>:右移。将二进制位整体向右移动n位,左边补符号位(有符号数)或0(无符号数)。

例如:

int a = 5; // 101
int b = 3; // 011
int c = a & b; // 结果为 001 → 1

常用位运算技巧

熟练运用以下技巧可以简化代码并提高效率:

立即学习C++免费学习笔记(深入)”;

1. 判断奇偶性
n & 1 可快速判断一个数是否为奇数。如果结果为1,说明最后一位是1,即为奇数。

if (n & 1) {
  cout }

2. 快速乘以或除以2的幂
左移n位等价于乘以2^n,右移n位等价于除以2^n(对非负数有效)。

x x >> 2; // x / 4

3. 清除最右侧的1位
表达式 n & (n-1) 能快速清除最右边的一个1。常用于统计1的个数。

while (n) {
  n = n & (n - 1);
  count++;
}

4. 提取最右侧的1
使用 n & (-n) 可提取最右边的1,其余位清零。这在树状数组(Fenwick Tree)中很常见。

5. 交换两个数无需临时变量
利用异或的性质:a ^ a = 0a ^ 0 = a

a ^= b;
b ^= a;
a ^= b;

但这种写法在现代编程中不推荐,可读性差且在a、b指向同一地址时有问题。

绘蛙AI修图
绘蛙AI修图

绘蛙平台AI修图工具,支持手脚修复、商品重绘、AI扩图、AI换色

下载

实际应用场景

位运算在很多高效编程实践中都有体现:

1. 状态压缩(状态DP)
用一个整数表示多个布尔状态。比如集合{0, 2, 3}可以用二进制1101表示。

if (state & (1   // 第i个元素被选中
}

2. 标志位管理
定义多个标志,用或组合,用与检测。

const int READ = 1 const int WRITE = 1 const int EXEC = 1
int perm = READ | WRITE; // 赋予读写权限
if (perm & EXEC) { ... } // 检查是否有执行权限

3. 高效计算汉明权重(1的个数)
除了 n & (n-1),也可以使用内置函数:

int count = __builtin_popcount(n); // GCC内置函数

这个函数底层经过高度优化,比循环更快。

注意事项与陷阱

使用位运算时需注意以下几点:

  • 不要对负数进行左移操作,行为未定义。
  • 右移有符号负数时,结果依赖于编译器实现(通常算术右移)。
  • 确保数据类型足够大,避免移位溢出,如对int左移31位可能溢出。
  • 优先级问题:位运算符优先级低于比较运算符,记得加括号。例如:if ((a & mask) == target)

基本上就这些。位运算看似低层,但在优化关键路径时非常有用。掌握这些技巧后,你会发现很多原本需要循环或条件判断的问题,可以用几行位操作优雅解决。关键是理解二进制表示的本质,多练习常见模式。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

297

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

216

2025.10.31

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

222

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

84

2025.10.17

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

711

2023.08.22

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

192

2023.11.20

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

81

2023.09.25

小游戏4399大全
小游戏4399大全

4399小游戏免费秒玩大全来了!无需下载、即点即玩,涵盖动作、冒险、益智、射击、体育、双人等全品类热门小游戏。经典如《黄金矿工》《森林冰火人》《狂扁小朋友》一应俱全,每日更新最新H5游戏,支持电脑与手机跨端畅玩。访问4399小游戏中心,重温童年回忆,畅享轻松娱乐时光!官方入口安全绿色,无插件、无广告干扰,打开即玩,快乐秒达!

30

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 5.6万人学习

C 教程
C 教程

共75课时 | 3.8万人学习

C++教程
C++教程

共115课时 | 10.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号