代码训练LeetCode(13)颠倒二进制位

这篇具有很好参考价值的文章主要介绍了代码训练LeetCode(13)颠倒二进制位。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

代码训练(13)LeetCode之颠倒二进制位

Author: Once Day Date: 2024年4月9日

漫漫长路,才刚刚开始…

全系列文章可参考专栏: 十年代码训练_Once-Day的博客-CSDN博客

参考文章:

  • 190. 颠倒二进制位 - 力扣(LeetCode)
  • 力扣 (LeetCode) 全球极客挚爱的技术成长平台
1. 原题

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

原题目要求实现一个函数,输入是一个32位无符号整数,输出也是一个32位无符号整数,它是输入数字二进制表示的颠倒。

例如,若输入的整数的二进制表示是0000010100101000001111010011100

则输出应为00111001011110000010100101000000,即将输入的二进制位从右向左排列后得到的结果。

2. 分析

颠倒一个整数的二进制位,可以通过多次将原数字右移并取出最低位,然后将这个位左移相应的位置添加到新数字中去的方法来实现。我们可以用一个循环,每次迭代处理一个位。

分析步骤

  1. 初始化一个变量,用于存储最终颠倒后的结果。
  2. 进行32次循环,因为我们处理的是一个32位的整数。
  3. 在每次循环中,将结果变量向左移动一位,为即将添加的最低位腾出空间。
  4. 使用按位与操作取得原始整数的最低位。
  5. 将这个最低位添加到结果变量中。
  6. 将原始整数右移一位,丢弃已经处理过的最低位。
  7. 循环结束后,结果变量中存储的就是颠倒后的整数。

假设输入整数为2,二进制表示为00000000000000000000000000000010

  1. 初始化结果变量为0:00000000000000000000000000000000
  2. 第一次循环:
    • 结果左移:00000000000000000000000000000000
    • 输入右移:00000000000000000000000000000001,取得最低位为2(10)。
    • 结果变量现在为:00000000000000000000000000000010
  3. 继续这个过程,直到处理完32次。

性能优化关键点

  1. 执行速度优化:由于只需要进行固定次数的位操作,所以算法的执行速度已经很快。确保没有不必要的操作或函数调用。
  2. 内存使用优化:只需要存储输入整数和结果整数,所以内存使用已经很少。
3. 代码实现
uint32_t reverseBits(uint32_t n) {
    uint32_t result = 0;
    for (int i = 0; i < 32; i++) {
        result <<= 1;
        result |= (n & 1);
        n >>= 1;
    }
    return result;
}

在上面的代码中,reverseBits函数是进行颠倒操作的核心。使用了一个for循环来迭代32次,每次将结果变量result左移一位,并将原始整数n的最低位使用按位与(&)操作取出,通过按位或(|)操作添加到result中。原始整数通过右移操作丢弃最低位。函数最终返回颠倒后的结果。

运行结果如下所示(仅供参考):

代码训练LeetCode(13)颠倒二进制位,#  十年代码训练,leetcode,算法,c语言

4. 总结

这个问题考察了对位操作的掌握,包括左移、右移、按位与和按位或。这些操作是底层编程、嵌入式系统开发和性能优化中的重要工具。文章来源地址https://www.toymoban.com/news/detail-859793.html

到了这里,关于代码训练LeetCode(13)颠倒二进制位的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【LeetCode】67. 二进制求和

    难度:简单 给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。 示例 1: 示例 2: 提示: 1 = a.length, b.length = 10^4 a 和 b 仅由字符 \\\'0\\\' 或 \\\'1\\\' 组成 字符串如果不是 \\\"0\\\" ,就不含前导零 思路: 从后往前遍历字符逐个判断即可 最后考虑是否进位 sum 1 等价于 sum

    2024年02月05日
    浏览(52)
  • Leetcode67 二进制求和

    给你两个二进制字符串  a  和  b  ,以二进制字符串的形式返回它们的和。      代码  

    2024年02月11日
    浏览(41)
  • 【第36天】组合位运算训练 | 二进制思想

    本文已收录于专栏 🌸《Java入门一百例》🌸

    2024年02月01日
    浏览(37)
  • leetcode: 2861. 最大二进制奇数

    给你一个 二进制 字符串  s  ,其中至少包含一个  \\\'1\\\'  。 你必须按某种方式 重新排列 字符串中的位,使得到的二进制数字是可以由该组合生成的 最大二进制奇数 。 以字符串形式,表示并返回可以由给定组合生成的最大二进制奇数。 注意 返回的结果字符串 可以 含

    2024年03月13日
    浏览(54)
  • LeetCode 1253. 重构 2 行二进制矩阵

    力扣题目链接:https://leetcode.cn/problems/reconstruct-a-2-row-binary-matrix/ 给你一个  2  行 n 列的二进制数组: 矩阵是一个二进制矩阵,这意味着矩阵中的每个元素不是  0  就是  1 。 第 0 行的元素之和为  upper 。 第 1 行的元素之和为 lower 。 第 i 列(从 0 开始编号)的元素之和为

    2024年02月11日
    浏览(41)
  • 【LeetCode】每日一题 - 负二进制转化

    负二进制转换 给你一个整数  n  ,以二进制字符串的形式返回该整数的  负二进制( base -2 ) 表示。 注意, 除非字符串就是  \\\"0\\\" ,否则返回的字符串中不能含有前导零。 示例 1: 示例 2: 示例 3: 提示: 0 = n = 109 思路:将一个十进制的数 n 转化为任意 x 进制都可以使用

    2024年04月29日
    浏览(50)
  • ​LeetCode解法汇总1073. 负二进制数相加

    https://github.com/September26/java-algorithms 给出基数为  -2  的两个数  arr1  和  arr2 ,返回两数相加的结果。 数字以  数组形式   给出:数组由若干 0 和 1 组成,按最高有效位到最低有效位的顺序排列。例如, arr = [1,1,0,1]  表示数字  (-2)^3 + (-2)^2 + (-2)^0 = -3 。 数组形式  中的数

    2024年02月05日
    浏览(39)
  • leetcode 1290.二进制链表转整数

    🌟 leetcode链接:二进制链表转整数 ps: 代码:

    2024年02月14日
    浏览(62)
  • ​LeetCode解法汇总253. 重构 2 行二进制矩阵

    https://github.com/September26/java-algorithms 给你一个  2  行  n  列的二进制数组: 矩阵是一个二进制矩阵,这意味着矩阵中的每个元素不是  0  就是  1 。 第  0  行的元素之和为  upper 。 第  1  行的元素之和为  lower 。 第  i  列(从  0  开始编号)的元素之和为  colsum[i] ,

    2024年02月11日
    浏览(49)
  • 算法leetcode|67. 二进制求和(rust重拳出击)

    给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。 1 = a.length, b.length = 10 4 a 和 b 仅由字符 \\\'0\\\' 或 \\\'1\\\' 组成 字符串如果不是 \\\"0\\\" ,就不含前导零 面对这道算法题目,二当家的再次陷入了沉思。 直接用API将字符串按照2进制转成整型,相加,然后再按照2进制转

    2024年02月14日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包