算法:位运算

位运算题型与Java算法技巧

一、位运算基础

位运算符 含义 示例
& 按位与 5 & 3 = 1
` ` 按位或 `5 3 = 7`
^ 按位异或 5 ^ 3 = 6
~ 按位取反 ~5 = -6
<< 左移 5 << 1 = 10
>> 右移(带符号) -2 >> 1 = -1
>>> 右移(无符号) -2 >>> 1 = 2147483647

位运算特点

  • XOR 特性:

    • a ^ a = 0
    • a ^ 0 = a
    • a ^ b ^ a = b
  • 检查奇偶性: (n & 1) == 0 偶数, (n & 1) == 1 奇数

  • 快速乘除 2 的幂:

    • n << k → n * (2^k)
    • n >> k → n / (2^k)
  • 清零/取低位:

    • n & (n-1) → 清掉最低位的 1
    • n & -n → 取出最低位的 1

二、题型分类与技巧

1. 判断奇偶

java 复制代码
boolean isOdd(int n) {
    return (n & 1) == 1;
}

2. 交换两个数

java 复制代码
a ^= b;
b ^= a;
a ^= b;

3. 数组中唯一出现的数

java 复制代码
int singleNumber(int[] nums) {
    int res = 0;
    for (int num : nums) res ^= num;
    return res;
}

4. 位计数 / 汉明重量

java 复制代码
int hammingWeight(int n) {
    int count = 0;
    while (n != 0) {
        n &= (n - 1);
        count++;
    }
    return count;
}

5. 判断是否为 2 的幂

java 复制代码
boolean isPowerOfTwo(int n) {
    return n > 0 && (n & (n-1)) == 0;
}

6. 子集 / 状态压缩 DP

java 复制代码
int n = 3;
for (int mask = 0; mask < (1 << n); mask++) {
    for (int i = 0; i < n; i++) {
        if ((mask & (1 << i)) != 0) {
            System.out.print(i + " ");
        }
    }
    System.out.println();
}

7. 快速乘除法

java 复制代码
int mul = n << 3; // n * 8
int div = n >> 2; // n / 4

8. 找出二进制中不同的位

java 复制代码
int diffBit = a ^ b;
int lowestDiff = diffBit & -diffBit;

三、位运算常用模板

  1. XOR 找单数
java 复制代码
int res = 0;
for (int num : nums) res ^= num;
return res;
  1. 清零最低位 1
java 复制代码
while (n != 0) {
    n &= (n-1);
}
  1. 子集遍历
java 复制代码
for (int mask = 0; mask < (1<<n); mask++) {
    // 遍历 mask 的每一位
}
  1. 判断 2 的幂
java 复制代码
(n > 0) && ((n & (n-1)) == 0);
  1. 交换两个数
java 复制代码
a ^= b; b ^= a; a ^= b;
相关推荐
搞笑症患者12 分钟前
压缩感知(Compressed Sensing, CS)
算法·最小二乘法·压缩感知·正交匹配追踪omp·迭代阈值it算法
im_AMBER16 分钟前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
快手技术33 分钟前
AAAI 2026|全面发力!快手斩获 3 篇 Oral,12 篇论文入选!
前端·后端·算法
颜酱35 分钟前
前端算法必备:滑动窗口从入门到很熟练(最长/最短/计数三大类型)
前端·后端·算法
做科研的周师兄37 分钟前
【MATLAB 实战】栅格数据 K-Means 聚类(分块处理版)—— 解决大数据内存溢出、运行卡顿问题
人工智能·算法·机器学习·matlab·kmeans·聚类
X在敲AI代码37 分钟前
leetcodeD3
数据结构·算法
码农小韩1 小时前
基于Linux的C++学习——循环
linux·c语言·开发语言·c++·算法
CoderCodingNo1 小时前
【GESP】C++五级/四级练习(双指针/数学) luogu-P1147 连续自然数和
开发语言·c++·算法
颜酱1 小时前
前端算法必备:双指针从入门到很熟练(快慢指针+相向指针+滑动窗口)
前端·后端·算法
Wect1 小时前
LeetCode 274. H 指数:两种高效解法全解析
算法·typescript