位运算 计算

符号 名称 运算规则 蓝桥杯常见应用
& 按位与 两位都为1时,结果为1 判断奇偶 (x & 1)、清零特定位、取模(对2的幂)
` ` 按位或 两位都为0时,结果为0,否则为1
^ 按位异或 两位相同为0,不同为1 查找单身数字不使用临时变量交换数值
~ 按位取反 0变1,1变0 配合&运算实现特定位清零 (x & ~(1 << k))
<< / >> 左移/右移 将所有位向左/右移动 快速进行乘/除2的幂运算、获取或设置特定位

核心技巧:竞赛中的杀手锏

  1. 异或 (^) 的神奇用法 :异或运算的核心性质是 x ^ x = 0x ^ 0 = x,由此衍生出几个竞赛中非常巧妙的用法。

    • "单身狗"问题:在一个数组中,除了一个元素出现奇数次外,其他元素均出现偶数次。将所有元素异或起来,最终结果就是那个"落单"的元素。

    • 交换两个数 :无需临时变量,利用异或的自反性,使用 a ^= b; b ^= a; a ^= b; 三步即可完成交换。

    • 快速判断两个数是否相等 :直接 (a ^ b) == 0

  2. "与"运算 (&) 的精妙用法

    • 判断奇偶(x & 1) == 1 为奇数,(x & 1) == 0 为偶数。

    • 判断2的幂次x > 0(x & (x - 1)) == 0,则 x 是2的幂次。

    • 统计二进制中1的个数 :通过 x = x & (x - 1) 循环,每执行一次就消除一个最低位的1,直到 x 变为0,循环次数即1的个数。

    • 计算 lowbitlowbit = x & -x 可以提取出 x 的二进制表示中最低位的1所代表的值。这是树状数组实现的基础,也是在状态压缩DP中枚举子集的关键。

相关推荐
运筹vivo@几秒前
3043. 最长公共前缀的长度(Leetcode 每日一题)
c++·算法·leetcode·职场和发展·每日一题
心中有国也有家10 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事11 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院11 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
csdn_aspnet11 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
m0_6294947314 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户14 小时前
用队列实现栈
数据结构·算法
做人求其滴15 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad77715 小时前
记一组无人机IMU传感器数据
算法