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)

        
相关推荐
紫陌涵光8 分钟前
108.将有序数组转换为二叉搜索树
数据结构·算法·leetcode
iAkuya18 分钟前
(leetcode)力扣100 75前K个高频元素(堆)
java·算法·leetcode
henry10101021 分钟前
Ansible自动化运维全攻略(AI生成)
linux·运维·python·ansible·devops
载数而行52042 分钟前
算法系列2之最短路径
c语言·数据结构·c++·算法·贪心算法
weixin_440401691 小时前
Python数据分析(空值、重复值检测删除与设置)
开发语言·python·数据分析
逆境不可逃2 小时前
【除夕篇】LeetCode 热题 100 之 189.轮转数组
java·数据结构·算法·链表
xiaoye-duck2 小时前
《算法题讲解指南:优选算法-滑动窗口》--13 水果成篮
c++·算法
wefg12 小时前
【算法】模运算的技巧
算法
智者知已应修善业2 小时前
【冰雹猜想过程逆序输出】2025-4-19
c语言·c++·经验分享·笔记·算法