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)

        
相关推荐
甄心爱学习12 小时前
KMP算法(小白理解)
开发语言·python·算法
培培说证12 小时前
2026 高职计算机专业考证选择哪个更实用?
python
wen__xvn12 小时前
牛客周赛 Round 127
算法
大锦终13 小时前
dfs解决FloodFill 算法
c++·算法·深度优先
ASD123asfadxv13 小时前
LCD屏幕表面缺陷检测系统凹陷识别与定位技术分析
python
橘颂TA13 小时前
【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量
算法·leetcode·职场和发展
Ulyanov13 小时前
大规模战场数据与推演:性能优化与多视图布局实战
开发语言·python·性能优化·tkinter·pyvista·gui开发
苦藤新鸡13 小时前
14.合并区间(1,3)(2,5)=(1,5)
c++·算法·leetcode·动态规划
tjjucheng13 小时前
小程序定制开发哪家口碑好
python
tjjucheng13 小时前
小程序定制开发源头厂家
python