博客
关于我
LeetCode0190. 颠倒二进制位
阅读量:301 次
发布时间:2019-03-03

本文共 567 字,大约阅读时间需要 1 分钟。

一. 题目
  1. 题目

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

  2. 示例

    在这里插入图片描述

二. 方法一: 拼接 + 反转
  1. 解题思路

  2. 解题代码

    def reverseBits(self, n: int) -> int:    bin_num = bin(n)    size = 34 - len(bin_num)    result = "0b" + bin_num[-1: 1: -1] + "0" * size    return int(result, 2)
  3. 分析

    时间复杂度: O(1)
    空间复杂度: O(1)

三. 方法二
  1. 解题思路

    1. 先将输入的数字转成32位长的二进制数
    2. 然后再从右向左进行计算
    3. 算出最终结果即可
  2. 解题代码

    def reverseBits(self, n: int) -> int:    bin_num = bin(n)    size = 34 - len(bin_num)    bin_num = "0b" + "0" * size + bin_num[2:]    result = 0    for ele in bin_num[-1:1:-1]:        result = (result << 1) + int(ele)    return result
  3. 分析

    时间复杂度: O(1)
    空间复杂度: O(1)

转载地址:http://qium.baihongyu.com/

你可能感兴趣的文章
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>