【位运算】基础算法总结

目录

基础位运算

  • <<
  • >>
  • ~ :按位取反
  • &:有0就是0(按位与)
  • | :有1就是1(按位或)
  • ^ :相同为0,相异为1/无进位相加(按位异或)
  • 规则:

    从右往左的下标一直由0->31

给一个数n,确定它的二进制表示的第x位是0还是1

cpp 复制代码
(n>>x) &1

将一个数n的二进制表示的第x位修改成1

cpp 复制代码
n |= (1<<x)

将一个数n的二进制表示的第x位修改成0

cpp 复制代码
n &= (~(1<<x))

位图思想(哈希表)

int:32位

利用32位的每一位0/1来记录信息。

提取一个数(n)二进制表示中的最右侧的1(lowbit)

01110101000

->

00000001000

  • -n的本质:
    n按位取反+1(补码)
    将最右侧中的1,左边的区域(不包括最右侧的1)全部变成相反

所以最右侧的1的左边区域全部&上n会为0,右侧全是0,&上也是0

cpp 复制代码
n&-n

干掉一个数n二进制表示中最右侧的1

  • n-1的本质:
    最右侧的1的右侧(包括最右侧的1)全部变为相反
cpp 复制代码
n&n-1

异或

1.a^0 = a

2.a^a = 0

3.a ^ b ^ c = a ^ (b ^ c) --- 符合交换律和结合律

相关推荐
通信小呆呆5 分钟前
DDMA MIMO OFDM ISAC:从回波模型到距离-速度图与非相参积累的原理梳理
算法·信息与通信·ofdm·mimo·通信感知一体化
王燕龙(大卫)15 分钟前
linuxptp时间同步
c++
leo__52022 分钟前
电动助力转向(EPS)系统Simulink模型构建与应用
算法
TracyCoder12327 分钟前
LeetCode Hot100(8/100)—— 438. 找到字符串中所有字母异位词
算法·leetcode
郝学胜-神的一滴28 分钟前
深入理解Linux套接字(Socket)编程:从原理到实践
linux·服务器·开发语言·网络·c++·程序人生·算法
程序猿编码29 分钟前
高性能HTTP服务压测工具:设计思路与实现原理(C/C++代码实现)
c语言·网络·c++·网络协议·tcp/ip·http
2301_8035545244 分钟前
c++hpc岗位
c++
坐怀不乱杯魂1 小时前
Linux - 线程
linux·c++
DuHz1 小时前
UWB 雷达综述精读:应用、标准、信号处理、数据集、芯片与未来方向——论文阅读
论文阅读·学习·算法·信息与通信·信号处理