python基础:位置互换

python 复制代码
n = int(input())
for _ in range(n):
    line = input().strip()
    line = list(line)
    for i in range(1,len(line)+1):
        if i%2 == 0:
            line[i-2], line[i-1] = line[i-1],line[i-2] 
    print(''.join(line))
        
   

以下分不同数据类型说明 Python 实现奇偶互换的方法:

字符串的奇偶位互换

若字符串长度为偶数,可通过遍历字符串,两两交换相邻字符实现。示例代码如下:

复制代码
def swap_odd_even_str(s):
    chs = list(s)
    for i in range(0, len(chs) - 1, 2):
        chs[i], chs[i + 1] = chs[i + 1], chs[i]
    return ''.join(chs)

# 测试
s = "python"
print(swap_odd_even_str(s))  # 输出:yptohn

这里先将字符串转为列表方便操作,range(0, len(chs) - 1, 2) 从索引 0 开始,每次步进 2 遍历,利用 Python 的多重赋值语法交换相邻字符,最后用 join() 方法将列表转回字符串。

若字符串长度为奇数,一般处理方式是除最后一个字符外,前面部分进行奇偶位互换:

复制代码
def swap_odd_even_str(s):
    chs = list(s)
    for i in range(0, len(chs) - 1 if len(chs) % 2 == 0 else len(chs) - 2, 2):
        chs[i], chs[i + 1] = chs[i + 1], chs[i]
    return ''.join(chs)

# 测试
s = "hello"
print(swap_odd_even_str(s))  # 输出:ehllo

列表的奇偶位置元素互换

对列表中索引为奇数和偶数位置的元素进行互换,示例代码如下:

复制代码
def swap_odd_even_list(lst):
    for i in range(1, len(lst), 2):
        lst[i - 1], lst[i] = lst[i], lst[i - 1]
    return lst

# 测试
lst = [1, 2, 3, 4, 5]
print(swap_odd_even_list(lst))  # 输出:[2, 1, 4, 3, 5]

range(1, len(lst), 2) 从索引 1 开始,每次步进 2,即遍历所有奇数索引位置,然后交换相邻的奇偶位置元素。

数值的奇偶性互换(将奇数变为偶数,偶数变为奇数 )

可以通过判断数值的奇偶性,然后进行相应运算实现。比如对整数加 1 或减 1:

复制代码
def swap_odd_even_num(num):
    if num % 2 == 0:
        return num + 1
    else:
        return num - 1

# 测试
num = 5
print(swap_odd_even_num(num))  # 输出:4
num = 6
print(swap_odd_even_num(num))  # 输出:7

这里先判断数字是否为偶数(num % 2 == 0 ),如果是则加 1;如果是奇数则减 1 ,从而实现奇偶性互换。

相关推荐
墨染点香1 分钟前
LeetCode 刷题【10. 正则表达式匹配】
算法·leetcode·职场和发展
cookqq2 分钟前
mongodb源代码分析createCollection命令由create.idl变成create_gen.cpp过程
数据库·算法·mongodb·nosql
clock的时钟5 分钟前
数据结构-线性表顺序表示
数据结构·算法
java1234_小锋17 分钟前
【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - snowNLP库实现中文情感分析
python·自然语言处理·flask
wait a minutes31 分钟前
【c++】leetcode5 最长回文子串
开发语言·c++
**梯度已爆炸**34 分钟前
Python Web框架详解:Flask、Streamlit、FastAPI
python·flask·fastapi·streamlit
WanderInk35 分钟前
深入解析:Java Arrays.sort(intervals, Comparator.comparingInt(a -> a[0])); 一行代码的背后功力
java·后端·算法
এ᭄画画的北北1 小时前
力扣-70.爬楼梯
算法·leetcode
nako_sayuri1 小时前
二分查找:区间内查询数字的频率
数据结构·算法