leetcode:面试题 05.07. 配对交换(python3解法)

难度:简单

配对交换。编写程序,交换某个整数的奇数位和偶数位,尽量使用较少的指令(也就是说,位0与位1交换,位2与位3交换,以此类推)。

示例1:

复制代码
 输入:num = 2(或者0b10)
 输出 1 (或者 0b01)

示例2:

复制代码
 输入:num = 3
 输出:3

提示:

  1. num的范围在[0, 2^30 - 1]之间,不会发生整数溢出。

题解:

python 复制代码
class Solution:
    def exchangeBits(self, num: int) -> int:
        if num == 1:
            return 2
        n = bin(num).split('b')[1]
        list_n = list(n)
        
        if len(n) % 2 == 1:
            list_n = ['0'] + list_n
        for i in range(0,len(list_n)-1,2):
            list_n[i],list_n[i+1] = list_n[i+1],list_n[i]
    
        return int("".join(['0b']+list_n),2)

        
相关推荐
信创天地5 分钟前
RISC-V 2025年在国内的发展趋势
python·网络安全·系统架构·系统安全·运维开发
Danceful_YJ18 分钟前
30.注意力汇聚:Nadaraya-Watson 核回归
pytorch·python·深度学习
FreeCode20 分钟前
LangChain1.0智能体开发:人机协作
python·langchain·agent
2501_9304122730 分钟前
如何添加清华源到Conda?
开发语言·python·conda
2501_9304122733 分钟前
如何删除Conda中的清华源配置?
开发语言·python·conda
leoufung1 小时前
贪心算法理论与应用——以股票买卖问题为例
算法·贪心算法
程序猿20231 小时前
Python每日一练---第十二天:验证回文串
开发语言·python
沿着路走到底1 小时前
python 判断与循环
java·前端·python
墨雪不会编程1 小时前
数据结构—排序算法篇三
数据结构·算法·排序算法