【每天学习一点算法 2026/01/21】倒二进制位

每天学习一点算法 2026/01/21

题目:颠倒二进制位

颠倒给定的 32 位有符号整数的二进制位。

  1. 最容易想到的办法就是颠倒二进制字符串再转换成数字(注意需要填充原数字二进制至 32 位)

    typescript 复制代码
    function reverseBits(n: number): number {
      const str = n.toString(2).padStart(32, '0') // 填充原数字二进制至32位
      return parseInt(str.split('').reverse().join(''), 2) // 颠倒二进制字符串再转换成整数
    };
  2. 另外这道题还可以利用分治的思想,将二进制分为两部分,对每部分递归执行翻转操作,具体思路如下:

    • 32 位二进制数 → 先交换高 16 位和低 16 位
    • 每个 16 位 → 交换高 8 位和低 8 位
    • 每个 8 位 → 交换高 4 位和低 4 位
    • 每个 4 位 → 交换高 2 位和低 2 位
    • 每个 2 位 → 交换高 1 位和低 1 位
    • 最终完成整体反转。

    首先交换高 16 位和低 16 位 很简单, n = (n >>> 16) | (n << 16)

    然后每个 16 位交换高 8 位和低 8 位,关键就在于如何选中每个 16 位的高 8 位和低 8 位,我们可以很容易的就想到利用掩码 11111111000000001111111100000000 & n 可以精准选中高 8 位,同理利用掩码 00000000111111110000000011111111可以选中低 8 位

    然后高位左移 8 位,低位右移 8 位即可,掩码我们用 16 进制 n = ((n & 0xff00ff00) >>> 8) | ((n & 0x00ff00ff) << 8)

    后续几步同理使用掩码选中再位移就能实现整个翻转:

    typescript 复制代码
    function reverseBits(n: number): number {
      n = (n >>> 16) | (n << 16) // 交换高 16 位和低 16 位
      n = ((n & 0xff00ff00) >>> 8) | ((n & 0x00ff00ff) << 8) // 交换每个 16 位的高 8 位和低 8 位
      n = ((n & 0xf0f0f0f0) >>> 4) | ((n & 0x0f0f0f0f) << 4) // 交换每个 8 位的高 4 位和低 4 位
      n = ((n & 0xcccccccc) >>> 2) | ((n & 0x33333333) << 2) // 交换每个 4 位的高 2 位和低 2 位
      n = ((n & 0xaaaaaaaa) >>> 1) | ((n & 0x55555555) << 1) // 交换每个 2 位的高 1 位和低 1 位
      return n
    };

题目来源:力扣(LeetCode)

相关推荐
三品吉他手会点灯1 天前
C语言学习笔记 - 20.C编程预备计算机专业知识 - 变量为什么必须的初始化【重点】
c语言·笔记·学习
sakiko_1 天前
UIKit学习笔记1-创建项目(使用UIKit)、使用组件
笔记·学习
Old Uncle Tom1 天前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆1 天前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移1 天前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业1 天前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
星幻元宇VR1 天前
VR航空航天科普设备【VR时空直升机】
科技·学习·安全·生活·vr
_李小白1 天前
【android opencv学习笔记】Day 2: Mat类(图片数据结构体)
android·opencv·学习
智者知已应修善业1 天前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
harder3211 天前
RMP模式的创新突破
开发语言·学习·ios·swift·策略模式