【资料整理】C语言位运算总结

本文详细介绍了C语言中的位运算基础知识,包括与、或、异或、取反、左移、右移操作符的规则,并探讨了位运算在判断奇偶、两数交换、改变符号、取绝对值、高低位互换、二进制逆序以及计算二进制中1的个数等实际应用。同时,提供了相应的代码示例,帮助读者深入理解位运算的实际运用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

位操作基础

基本的位操作符有与、或、异或、取反、左移、右移这6种,它们的运算规则如下所示:

符号

描述

运算规则

&

两个位都为1时,结果才为1

|

两个位都为0时,结果才为0

^

异或

两个位相同为0,相异为1

~

取反

0变1,1变0

<<

左移

各二进位全部左移若干位,高位丢弃,低位补0

>>

右移

各二进位全部右移若干位,对无符号数,高位补0,有符号数,各编译器处理方法不一样,有的补符号位(算术右移),有的补0(逻辑右移)

注意以下几点:

  1. 在这6种操作符,只有~取反是单目操作符,其它5种都是双目操作符。

  2. 位操作只能用于整形数据,其他类型进行位操作会被编译器报错。

  3. 对于移位操作,在微软的VC6.0和VS2008编译器都是采取算术称位即算术移位操作,算术移位是相对于逻辑移位,它们在左移操作中都一样,低位补0即可,但在右移中逻辑移位的高位补0而算术移位的高位是补符号位。如下面代码会输出-4和3。

位操作应用

  1. 位运算的简单应用

表达式

位运算等价

x+y

(x|y)+(x&y)

x-y

(x|~y)-(~x&y)

x^y

(x|y)-(x&y)

x|y

(x&~y)+y

x&y

(~x|y)-~x

x==y

(x-y|y-x)

x!=y

x-y|y-x

x< y

(x-y)^((x^y)&((x-y)^x))

x< y

(~x&y)|((~x|y)&(x-y)) //无符号x,y比较

x<=y

(~x|y)&((x^y)|~(y-x)) //无符号x,y比较

  1. 判断奇偶

只要根据最未位是0还是1来决定,为0就是偶数,为1就是奇数。因此可以用if (a & 1 == 0)代替if (a % 2 == 0)来判断a是不是偶数。可以得到如下代码:

1 bool isEven(int n) {
2     if (n & 1) {
3         return true;
4     else {
5         return false;
6     }
7 }
  1. 不使用第三变量的两数交换
1 void swap(int &a, int &b) {
2  
3     if (a != b) {
4         a ^= b;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值