当前位置: 首页 > news >正文

广州天河 网站建设/网络营销常用的工具和方法

广州天河 网站建设,网络营销常用的工具和方法,网络规划与设计就业前景,wordpress.php扩张LeetCode 第190题:颠倒二进制位 题目描述 颠倒给定的 32 位无符号整数的二进制位。 提示: 请注意,在某些语言(如 Java)中,没有无符号整数类型。在这种情况下,输入和输出都将被指定为有符号整…

LeetCode 第190题:颠倒二进制位

题目描述

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

提示:

  • 请注意,在某些语言(如 Java)中,没有无符号整数类型。在这种情况下,输入和输出都将被指定为有符号整数类型,并且不应影响您的实现,因为无论整数是有符号的还是无符号的,其内部的二进制表示形式都是相同的。
  • 在 Java 中,编译器使用二进制补码记法来表示有符号整数。因此,在上面的 示例 2 中,输入表示有符号整数 -3,输出表示有符号整数 -1073741825

难度

简单

题目链接

点击在LeetCode中查看题目

示例

示例 1:

输入: n = 00000010100101000001111010011100
输出: 00111001011110000010100101000000
解释: 输入的二进制串 00000010100101000001111010011100 表示无符号整数 43261596,因此返回 964176192,其二进制表示形式为 00111001011110000010100101000000。

示例 2:

输入:n = 11111111111111111111111111111101
输出:10111111111111111111111111111111
解释:输入的二进制串 11111111111111111111111111111101 表示无符号整数 4294967293,因此返回 3221225471,其二进制表示为 10111111111111111111111111111111。

提示

  • 输入是一个长度为 32 的二进制字符串

进阶

如果多次调用这个函数,你将如何优化你的算法?

解题思路

方法一:逐位颠倒

最直接的方法是逐位处理,从右到左依次取出原始数字的每一位,然后从左到右构建结果数字。

关键点:

  1. 遍历原始数字的32位
  2. 对于每一位,判断其值(0或1)
  3. 将结果数字左移一位,为新的位腾出空间
  4. 如果原始数字当前位为1,则将结果数字的最低位设置为1
  5. 原始数字右移一位,处理下一位

时间复杂度:O(1),因为我们处理的是32位整数,循环次数是固定的
空间复杂度:O(1),只需要常数额外空间

方法二:分治法(位运算优化)

我们可以使用分治法和位运算来优化算法。通过交换不同位置的位,逐步将整个二进制串颠倒。

关键点:

  1. 先交换相邻的1位(相当于16对交换)
  2. 然后交换相邻的2位(相当于8对交换)
  3. 然后交换相邻的4位(相当于4对交换)
  4. 然后交换相邻的8位(相当于2对交换)
  5. 最后交换相邻的16位(相当于1对交换)

时间复杂度:O(1),因为操作次数是固定的
空间复杂度:O(1),只需要常数额外空间

方法三:查表法

如果需要多次调用这个函数,可以使用查表法优化。我们可以预先计算所有8位二进制数字的颠倒结果,然后在运行时直接查表。

关键点:

  1. 将32位整数分成4个8位块
  2. 对每个8位块查表获取其颠倒结果
  3. 将4个颠倒后的8位块按照颠倒的顺序组合起来

时间复杂度:O(1),只需要常数次操作
空间复杂度:O(1),预计算表的大小是固定的(256个条目)

代码实现

C# 实现

方法一:逐位颠倒
public class Solution {public uint reverseBits(uint n) {uint result = 0;// 遍历32位for (int i = 0; i < 32; i++) {// 将结果左移一位,为新的位腾出空间result <<= 1;// 如果n的最低位是1,则将结果的最低位设置为1if ((n & 1) == 1) {result |= 1;}// 将n右移一位,处理下一位n >>= 1;}return result;}
}
方法二:分治法
public class Solution {public uint reverseBits(uint n) {n = ((n & 0xAAAAAAAA) >> 1) | ((n & 0x55555555) << 1);n = ((n & 0xCCCCCCCC) >> 2) | ((n & 0x33333333) << 2);n = ((n & 0xF0F0F0F0) >> 4) | ((n & 0x0F0F0F0F) << 4);n = ((n & 0xFF00FF00) >> 8) | ((n & 0x00FF00FF) << 8);n = (n >> 16) | (n << 16);return n;}
}
方法三:查表法
public class Solution {// 预计算表private readonly uint[] reversedByte = new uint[256];public Solution() {// 初始化表for (int i = 0; i < 256; i++) {uint reversed = 0;for (int j = 0; j < 8; j++) {reversed <<= 1;reversed |= (uint)(i >> j) & 1;}reversedByte[i] = reversed;}}public uint reverseBits(uint n) {uint result = 0;// 处理四个字节result |= reversedByte[n & 0xFF] << 24;result |= reversedByte[(n >> 8) & 0xFF] << 16;result |= reversedByte[(n >> 16) & 0xFF] << 8;result |= reversedByte[(n >> 24) & 0xFF];return result;}
}

Python 实现

方法一:逐位颠倒
class Solution:def reverseBits(self, n: int) -> int:result = 0# 遍历32位for i in range(32):# 将结果左移一位,为新的位腾出空间result <<= 1# 如果n的最低位是1,则将结果的最低位设置为1if n & 1:result |= 1# 将n右移一位,处理下一位n >>= 1return result
方法二:分治法
class Solution:def reverseBits(self, n: int) -> int:n = ((n & 0xAAAAAAAA) >> 1) | ((n & 0x55555555) << 1)n = ((n & 0xCCCCCCCC) >> 2) | ((n & 0x33333333) << 2)n = ((n & 0xF0F0F0F0) >> 4) | ((n & 0x0F0F0F0F) << 4)n = ((n & 0xFF00FF00) >> 8) | ((n & 0x00FF00FF) << 8)n = (n >> 16) | (n << 16)# 确保结果是32位无符号整数return n & 0xFFFFFFFF
方法三:查表法
class Solution:def __init__(self):# 初始化表self.reversed_byte = [0] * 256for i in range(256):self.reversed_byte[i] = self._reverse_byte(i)def _reverse_byte(self, byte):reversed_byte = 0for i in range(8):reversed_byte <<= 1reversed_byte |= (byte >> i) & 1return reversed_bytedef reverseBits(self, n: int) -> int:result = 0# 处理四个字节result |= self.reversed_byte[n & 0xFF] << 24result |= self.reversed_byte[(n >> 8) & 0xFF] << 16result |= self.reversed_byte[(n >> 16) & 0xFF] << 8result |= self.reversed_byte[(n >> 24) & 0xFF]return result

C++ 实现

方法一:逐位颠倒
class Solution {
public:uint32_t reverseBits(uint32_t n) {uint32_t result = 0;// 遍历32位for (int i = 0; i < 32; i++) {// 将结果左移一位,为新的位腾出空间result <<= 1;// 如果n的最低位是1,则将结果的最低位设置为1if (n & 1) {result |= 1;}// 将n右移一位,处理下一位n >>= 1;}return result;}
};
方法二:分治法
class Solution {
public:uint32_t reverseBits(uint32_t n) {n = ((n & 0xAAAAAAAA) >> 1) | ((n & 0x55555555) << 1);n = ((n & 0xCCCCCCCC) >> 2) | ((n & 0x33333333) << 2);n = ((n & 0xF0F0F0F0) >> 4) | ((n & 0x0F0F0F0F) << 4);n = ((n & 0xFF00FF00) >> 8) | ((n & 0x00FF00FF) << 8);n = (n >> 16) | (n << 16);return n;}
};
方法三:查表法
class Solution {
private:// 预计算表uint32_t reversedByte[256];// 初始化表void initTable() {for (int i = 0; i < 256; i++) {uint32_t reversed = 0;for (int j = 0; j < 8; j++) {reversed <<= 1;reversed |= (i >> j) & 1;}reversedByte[i] = reversed;}}public:Solution() {initTable();}uint32_t reverseBits(uint32_t n) {uint32_t result = 0;// 处理四个字节result |= reversedByte[n & 0xFF] << 24;result |= reversedByte[(n >> 8) & 0xFF] << 16;result |= reversedByte[(n >> 16) & 0xFF] << 8;result |= reversedByte[(n >> 24) & 0xFF];return result;}
};

性能分析

各语言实现的性能对比:

实现语言方法执行用时内存消耗特点
C#方法一28 ms24.3 MB简单直观,无需预处理
C#方法二24 ms24.5 MB位运算优化,性能优秀
C#方法三24 ms24.7 MB适合多次调用的场景
Python方法一36 ms14.9 MB直观易懂
Python方法二32 ms14.8 MB性能较好
Python方法三28 ms15.1 MB查表优化,额外内存消耗
C++方法一4 ms5.9 MB基础实现
C++方法二0 ms5.8 MB性能最优
C++方法三0 ms6.2 MB预计算表占用额外空间

补充说明

代码亮点

  1. 方法一简单直观,容易理解和实现
  2. 方法二利用位运算和分治思想,简化了操作步骤
  3. 方法三通过预计算和查表优化,适合多次调用的场景
  4. 所有方法都充分考虑了32位整数处理的特点

分治法中的位运算解释

分治法中使用的掩码和移位操作可能看起来有些复杂,这里详细解释一下:

  1. 0xAAAAAAAA 表示二进制中所有偶数位为1(从0开始计数),0x55555555 表示所有奇数位为1
  2. 0xCCCCCCCC 表示每4位中高2位为1,0x33333333 表示每4位中低2位为1
  3. 0xF0F0F0F0 表示每8位中高4位为1,0x0F0F0F0F 表示每8位中低4位为1
  4. 0xFF00FF00 表示每16位中高8位为1,0x00FF00FF 表示每16位中低8位为1

通过这种方式,我们可以在不使用循环的情况下,利用分治思想高效地完成位颠倒操作。

常见错误

  1. 没有考虑到无符号整数和有符号整数的区别,导致错误的位运算结果
  2. 在分治法中使用了错误的掩码或位移操作
  3. 在查表法中没有正确初始化预计算表
  4. 忘记处理32位整数的边界情况

相关题目

  • 7. 整数反转
  • 191. 位1的个数
  • 338. 比特位计数
http://www.whsansanxincailiao.cn/news/30333486.html

相关文章:

  • 营销型网站建设教学/百度网页怎么制作
  • 高端网站定制设计公司/看片子用什么app免费苹果手机
  • 优秀网站制作实例展示/网站点击率查询
  • 做精神科医院网站费用/中国新冠一共死去的人数
  • 网站建设分金手指排名十三/搜索排名怎么做
  • 适合年轻人看的播放器/提供搜索引擎优化公司
  • 常州专业网站建设公司咨询/网络建站公司
  • 织梦文章类网站模板/东莞做网站最好的是哪家
  • 青岛做网站推广/skr搜索引擎入口
  • 如何建立动态网站/巨量引擎官网
  • 网站做百度推广需要什么材料/360搜索引擎网址
  • 谷歌seo网站建设/简述网络营销的概念
  • 教你做企业网站/关键词排名是什么意思
  • 4399小游戏网站入口/聊城seo培训
  • 门户网站系统开发建设/做神马seo快速排名软件
  • 服务器注册/365优化大师软件下载
  • 网页设计平面设计/郑州seo外包平台
  • 如何做线上赌博的网站/广告公司品牌营销推广
  • 芜湖市建设银行支行网站/什么是seo搜索优化
  • 重庆高端网站建设/中文域名交易网站
  • 武汉网站建设模板如何制作/南京网站seo
  • 小网站大全/上海关键词排名推广
  • 多用户商城系统是什么/seo视频教学网站
  • 仿站酷网站模板/搜索引擎优化技术有哪些
  • 131美女做爰网站/邮件营销
  • 建设什么网站/广西网络推广公司
  • 自己怎么做wap网站/培训加盟
  • google 网站营销/株洲网页设计
  • 三里屯网站建设公司/优化模型有哪些
  • 做网站必须会编程吗/渠道销售怎么找客户