【Python3】【力扣题】190. 颠倒二进制位

news2024/10/6 5:06:17

【力扣题】题目描述:

【Python3】代码:

1、解题思路:将整数转为二进制字符串,截取、反转、补足32位,再转回整数。

知识点:bin(...):转为二进制字符串,即‘0bxx...’。

             str [2:]:切片,从第2位开始截取字符串。

             str [::-1]:反转字符串,即第1个变成最后一个,第2个变成倒数第2个,...。

              str.ljust(...):左对齐,并指定字符补足右边空缺位数。

              int(...):转为整数。

       另:str.replace(old,new):字符串中用new替换old。

              str1+str2:字符串拼接。(例如:“1”+“2”=“12”)

              len(str):获取字符串长度。

class Solution:
    def reverseBits(self, n: int) -> int: 
        return int(bin(n)[2:][::-1].ljust(32,'0'),2)
        # 或者
        return int(bin(n).replace("0b","")[::-1].ljust(32,'0'),2)
        # 或者
        return int((bin(n)[2:][::-1]+"0"*32)[:32],2)
        # 或者
        a = bin(n).replace("0b","")[::-1]
        m = 32 - len(a)
        for i in range(m):
            a += "0"
        return int(a,2)

2、解题思路:位移。将二进制从低到高依次枚举每一位,反转到对应位置(例如:最低位反转到最高位)。

 知识点:n & 1:获取二进制低位的一位。整数n和1进行二进制与运算。(二进制中,1&1=1,1&0=0,0&0=0)

             res |= x:res和x进行二进制或运算,并重新赋值给res。

              << (31-i):左移(31-i)位。例如:第0位左移到第31位。

              n >>= 1:n右移一位,并重新赋值给n。

        另:range(31,-1,-1):  从31到0的数组(含31不含-1)。即依次31、30、29、...2、1、0。

class Solution:
    def reverseBits(self, n: int) -> int:       
        res = 0        #记录反转结果
        for i in range(32):
            res |= (n & 1) << (31-i)
            n >>= 1
        return res
        # 或者
        res = 0
        for i in range(31,-1,-1):
            res |= (n & 1) << i
            n >>= 1
        return res

 

3、解题思路:分治算法。将32位分成两个16位,16位再分成两个8位,...,2位最后分成两个1位。再回溯反转合并,两个1位反转合并成2位,两个2位再反转合并成4位,...,两个16位最后反转合并成32位。

知识点:二进制与运算:1&1=1,1&0=0,0&0=0。和0与都为0,和1与都为自身。

               二进制或运算:1 | 1=1,1 | 0=1,0 | 0=0。

              python里不对位数做限制,所以左移后必须“与” 一个0xffffffff ,表示只取32位。

注解:0x55555555即01010101...01010101。左移1位再和其“与”运算,和其“与”运算再右移1位,相当于两个1位互换位置。

0x33333333即00110011...00110011。左移2位再和其“与”运算,和其“与”运算再右移2位,相当于两个2位互换位置。

0x0f0f0f0f、0x00ff00ff 同理。

class Solution:
    def reverseBits(self, n: int) -> int:   
        # python里不对位数做限制,所以左移后必须“与” 一个0xffffffff ,表示只取32位
        M32 = 0xffffffff   # 11111111...11111111,即1*32
        M1 = 0x55555555    # 01010101...01010101
        M2 = 0x33333333    # 00110011...00110011
        M4 = 0x0f0f0f0f    # 00001111...00001111
        M8 = 0x00ff00ff    # 00000000...11111111

        n = (n >> 1) & M1 | ((n & M1) << 1) & M32
        n = (n >> 2) & M2 | ((n & M2) << 2) & M32
        n = (n >> 4) & M4 | ((n & M4) << 4) & M32
        n = (n >> 8) & M8 | ((n & M8) << 8) & M32
        return n >> 16 | (n << 16) & M32

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1136391.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

awk学习笔记1-常用awk操作

(一)awk简介 linux 三剑客之awk,AWK 是一种处理文本文件的语言&#xff0c;是一个强大的文本分析工具。grep,sed和awk都是读一行处理一行&#xff0c;直到处理完成。 grep &#xff1a; 过滤文本 sed : 修改文本 awk : 处理文本(主要用来格式化,将文本按照指定的格式输出) …

大模型 | NEFTune之引入随机噪声对大模型训练的收益

大模型 | NEFTune之引入随机噪声对大模型训练的收益 paper中提到&#xff0c;在模型foward过程中&#xff0c;对inputs_embedding增加适度的随机噪声&#xff0c;会带来显著的收益。 Paper: https://arxiv.org/pdf/2310.05914.pdf Github: https://github.com/neelsjain/NEFT…

苹果官宣新品发布会 10月31日发布会与Mac有关

10 月 25 日消息&#xff0c;苹果宣布将于北京时间 10 月 31 日上午 8 点举行主题为“来势迅猛”的线上特别活动&#xff0c;届时或将有新品发布。 这场发布会与以往不同&#xff0c;将在北京时间 10 月 31 日上午 8 点举行。有很多猜测认为苹果届时会发布新款 Mac 电脑&#x…

dropbear-ssh2

编译&#xff1a; ./configure --prefix/home/lxin/workdir/install-dropbear --with-zlib/home/lxin/workdir/zlib/install-zlib-1.2.11/ CCx86_64-linux-gnu-gcc make clean make make install 生产秘钥 in bin dir: ./dropbearkey -t rsa -f ../sbin/dropbear_rsa_host…

赢得国际市场:小企业的跨境电商品牌策略指南

随着全球化的快速发展&#xff0c;跨境电子商务已经成为小企业突破国界、实现全球化梦想的有效途径。然而&#xff0c;成功的跨境电商经营并不仅仅依赖于产品质量和价格竞争力&#xff0c;品牌营销同样至关重要。本文将深入探讨小企业如何在跨境电商领域做好品牌营销。 一、了解…

感受webWorker

B站视频 git完整代码 之前遇到的场景 1、vxe表格计算1000多条数极值/算数平方根的时候。 2、大文件上传时计算hashCode时候 一、不使用webWorker 目录结构 代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8&q…

使用Docker部署Apache Superset并实现公网远程访问

大数据可视化BI分析工具Apache Superset实现公网远程访问 文章目录 大数据可视化BI分析工具Apache Superset实现公网远程访问前言1. 使用Docker部署Apache Superset1.1 第一步安装docker 、docker compose1.2 克隆superset代码到本地并使用docker compose启动 2. 安装cpolar内网…

上帝视角看支付总架构解析

文章目录 1. 支付全局分层2. 交易服务层2.1 服务平台的支付架构2.2 架构的支付部分2.3 架构的清结算部分2.4 完整的架构 3. 支付服务层3.1 支付接收部分3.2 支付处理部分3.3 清结算部分 4. 清算服务层4.1 常见清算组织4.2 银联清算业务4.3 网联清算业务4.3.1 网联支持的业务4.3…

【Linux】 rpm安装包保存到本地并批量安装

目录 一、开启rpm安装包缓存到本地仓库 1. 修改yum.conf文件 2. 清理yum缓存 3. yum命令安装软件包 二、如何将rpm安装包保存到指定目录 方法一&#xff1a;yumdownloader 1. 安装yum-utils  2. yumdownloader命令参数说明 3. yumdownloader安装示例 方法二&#xff…

用Notepad++写java代码

步骤 1.新建&#xff0c;写代码 2.写好之后存为java文件 3.打开命令行 cd 对应位置 javac xxx.java &#xff08;如有中文&#xff09; java xxxdebug 1.错误: 编码utf-8的不可映射字符 这是代码里有中文&#xff0c;编译时加上-encoding utf-8即可 2.错误: 程序包xxx不存在…

ETO制造商目前面临的六大挑战,如何应对?

与离散制造、库存制造不同&#xff0c;按订单设计制造&#xff08;ETO&#xff09;行业面临着一系列独特的挑战。从复杂的产品设计到与客户的密切联系&#xff0c;按订单生产的每件产品都不尽相同。 如果采用按订单生产方式制造产品&#xff0c;管理者总是会想方设法采购最好的…

基于springboot实现书籍学习平台管理系统项目【项目源码+论文说明】

基于springboot实现书籍学习平台管理系统演示 摘要 首先,论文一开始便是清楚的论述了平台的研究内容。其次,剖析平台需求分析,弄明白“做什么”,分析包括业务分析和业务流程的分析以及用例分析,更进一步明确平台的需求。然后在明白了平台的需求基础上需要进一步地设计平台,主要…

礼品家居建材行业出口管理ERP解决方案

根据“一带一路”白皮书显示&#xff0c;2013至2022年&#xff0c;中国与共建国家进出口总额累计19.1万亿美元&#xff0c;年均增长6.4%&#xff1b;与共建国家双向投资累计超过3800亿美元。随着“一带一路”高质量共建&#xff0c;第134届广交会第二期打造的“大家居”主体概念…

Python教程:csv如何保存字典数据

下面是一个示例代码&#xff0c;它将字典数据保存到CSV文件中&#xff1a; #我的Python教程 #微信公众号&#xff1a;wdPython首先创建了一个包含字典数据的列表dict_data。然后&#xff0c;我们使用csv.DictWriter()函数创建一个CSV写入对象&#xff0c;指定了字典中的键作为…

智慧燃气,如何能够防患于未“燃”!

关键词&#xff1a;智慧燃气、智慧燃气建设、智慧燃气平台、智慧燃气系统、燃气数字化 天然气作为一种优质的清洁能源&#xff0c;在改善大气污染中起到非常重要的作用。国家也在将天然气发展成为我国主体能源之一。天然气的快速发展也给智慧燃气带来了光明的前途&#xff0c;…

【python】乱码的处理总结

Python 系列 如果你在Python中遇到了乱码问题&#xff0c;可能是由于字符编码不匹配导致的。以下是一些可能的解决方法&#xff1a; &#xff08;1&#xff09; 确认编码格式&#xff1a;首先要确认你的数据的实际编码格式。常见的编码格式包括UTF-8、GBK、GB2312等。确定正确…

goland无法调试问题解决

goland 无法调试问题解决 golang 版本升级后&#xff0c;goland 无法进行调试了 首先请看自己下载的版本是否有误 1.apple系 M系列芯片的 arm64版本 2.apple系 intel系列芯片的x86_64 3.windows系 intel解决如下&#xff1a; 查看gopath ericsanchezErics-Mac-mini gww-api…

一克商评|未来向外输出自动驾驶技术和解决方案的中国企业会越来越多

封面新闻记者 孟梅 欧阳宏宇 雷强 蔡世奇 付文超 小马智行获沙特新未来城1亿美元投资&#xff0c;并将成立合资公司 小马智行宣布获得沙特阿拉伯王国新未来城&#xff08;NEOM&#xff09;及旗下投资基金NIF&#xff08;NEOM Investment Fund&#xff09;的1亿美元投资。同时…

生成树协议:监控 STP 端口和交换机

什么是生成树协议 生成树协议 &#xff08;STP&#xff09; 用于网络交换机&#xff0c;以防止循环和广播风暴。在局域网 &#xff08;LAN&#xff09; 中&#xff0c;两条或多条冗余路径可以连接到同一网段。当交换机或网桥从所有可用端口传输帧时&#xff0c;这些帧开始在网…