位运算 计算

符号 名称 运算规则 蓝桥杯常见应用
& 按位与 两位都为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中枚举子集的关键。

相关推荐
地平线开发者34 分钟前
征程 6E/M Matrix 开发评板使用系列(一):开箱与点亮
算法·自动驾驶
Jerry1 小时前
LeetCode 59. 螺旋矩阵 II
算法
可编程芯片开发1 小时前
基于FOC控制器的BLDC无刷直流电机控制系统matlab编程与仿真
算法
aaaameliaaa2 小时前
进制练习题【找出只出现一次的数字、交换两个变量(不创建临时变量)、统计二进制中1的个数、打印整数二进制的奇数位和偶数位、求两个数二进制中不同位的个数】
c语言·数据结构·笔记·算法
QiLinkOS3 小时前
第三视觉理解徐玉生与他的商业活动(28)
大数据·c++·人工智能·算法·开源协议
wabs6664 小时前
关于动态规划【力扣1143.最长公共子序列的思考】
算法·leetcode·动态规划
剑挑星河月4 小时前
54.螺旋矩阵
java·算法·leetcode·矩阵
Robot_Nav4 小时前
MPPI 局部规划器实验设计讲解
人工智能·算法·mppi
mingo_敏5 小时前
Mean-Teacher 均值教师自训练框架详解
算法·均值算法
星空露珠5 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua