Python列表(list)反序(降序)的实现方式:原址反序,list.reverse()、list.sort()、全数组遍历、1/2数组遍历;新生成列表,resersed()、sorted()、负步长切片[::-1]。共七种方式,可以实现列表反序。
-
Python 官网:https://www.python.org/
-
Free:大咖免费“圣经”教程《 python 完全自学教程》,不仅仅是基础那么简单……
自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
—— 华罗庚
- My CSDN主页、My HOT博、My Python 学习个人备忘录
- 好文力荐、 老齐教室

本文质量分:
CSDN质量分查询入口:http://www.csdn.net/qc
◆ 数组反序的7种方式
1、试炼数组
lis = list('abcdefghijklmnopqrstuvwxyz')
print(f"\n\n序列:{lis}\n")
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
2、list方法
2.1 list.reverse()
可以利用列表方法,直接反序。reverse方法无返回值,原址操作列表。
lis = list('abcdefghijklmnopqrstuvwxyz')
lis.reverse() # reverse方法无返回值,原址反序操作列表。
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
反序:[‘z’, ‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
2.2 list.sort()
sort()方法无返回值,原址排序操作列表。其reverse参数默认=False,正序排序;令其=True,反序(降序)排序。
lis = list('abcdefghijklmnopqrstuvwxyz')
lis.sort(reverse=True) # sort方法无返回值,原址排序操作列表。
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
反序:[‘z’, ‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
3、轮询(遍历)
3.1 遍历整列表
用list.pop()模拟栈弹出,将弹出元素用list.insert()方法依次插入列表0~n-1位置,实现反序。
lis = list('abcdefghijklmnopqrstuvwxyz')
for i in range(len(lis)):
lis.insert(i, lis.pop())
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
反序:[‘z’, ‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
3.2 遍历数组1/2元素
从列表中间开始,依次对调前后元素实现反序。这要区分处理列表元素为奇偶的情况:奇,中间位置只有一个元素,不;偶,对调从处中间的两个元素开始对调。
a. 奇数个元素数组
数组元素总数为奇数,中间位置n=int(len(lis)/2)m,只有一个元素,不用对调。对调从下标n-1、n+1开始对调。
lis = list('abcdefghijklmnopqrstuvwxy')
n = int(len(lis)/2) # 计算中间位置。
for i in range(n+1):
print(lis[n-i], lis[1, n+i])
lis[n-i], lis[n+i] = lis[n+i], lis[n-i]
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
l n
k o
j p
i q
h r
g s
f t
e u
d v
c w
b x
a y
序列:[‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
反序:[‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
b. 偶数个元素数组
数组元素总数为偶数,中间位置n=int(len(lis)/2)±1之间,没有元素。对调从下标n-0、n+0开始对调。
n = int(len(lis)/2) - 1 # 计算中间位置。
lis = list('abcdefghijklmnopqrstuvwxyz')
n = int(len(lis)/2) - 1 # 计算中间位置。
for i in range(n+1):
print(lis[n-i], lis[n+i+1])
lis[n-i], lis[n+i+1] = lis[n+i+1], lis[n-i]
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
m n
l o
k p
j q
i r
h s
g t
f u
e v
d w
c x
b y
a z
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
反序:[‘z’, ‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
4、新生成列表实现反序
4.1 负步长切片
直接用[::-1]切片原列表,生成的新列表即已反序。
了解“切片”更多知识点,可以点击我的学习笔记“Python之魔幻切片”。
lis = list('abcdefghijklmnopqrstuvwxyz')
print(f"\n\n序列:{lis}\n\n反序:{lis[::-1]}\n")
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
反序:[‘z’, ‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
4.2 reversed()
效果同list.reverse()方法,不同的是reversed()函数不是原址操作列表,而是返回一个新列表。
lis = list('abcdefghijklmnopqrstuvwxyz')
print(f"\n返回类型:{type(reversed(lis))}\n")
print(f"\n\n序列:{lis}\n\n反序:{list(reversed(lis))}\n")
返回类型:<class ‘list_reverseiterator’>
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
反序:[‘z’, ‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
4.3 sorted()
效果同list.sort()方法,不同的是sorted()函数不是原址操作列表,而是返回一个新列表。
lis = list('abcdefghijklmnopqrstuvwxyz')
print(f"\n返回类型:{type(sorted(lis, reverse=True))}\n")
print(f"\n\n序列:{lis}\n\n反序:{sorted(lis, reverse=True)}\n")
返回类型:<class ‘list’>
序列:[‘a’, ‘b’, ‘c’, ‘d’, ‘e’, ‘f’, ‘g’, ‘h’, ‘i’, ‘j’, ‘k’, ‘l’, ‘m’, ‘n’, ‘o’, ‘p’, ‘q’, ‘r’, ‘s’, ‘t’, ‘u’, ‘v’, ‘w’, ‘x’, ‘y’, ‘z’]
反序:[‘z’, ‘y’, ‘x’, ‘w’, ‘v’, ‘u’, ‘t’, ‘s’, ‘r’, ‘q’, ‘p’, ‘o’, ‘n’, ‘m’, ‘l’, ‘k’, ‘j’, ‘i’, ‘h’, ‘g’, ‘f’, ‘e’, ‘d’, ‘c’, ‘b’, ‘a’]
5、完整源码
#!/sur/bin/nve
# coding: utf-8
# reverse()
lis = list('abcdefghijklmnopqrstuvwxyz')
lis.reverse() # reverse方法无返回值,原址反序操作列表。
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
input(' reverse()方法 '.center(48, '~'))
# sort()
lis = list('abcdefghijklmnopqrstuvwxyz')
lis.sort(reverse=True) # sort方法无返回值,原址排序操作列表。
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
input(' sort()方法 '.center(48, '~'))
# for all
lis = list('abcdefghijklmnopqrstuvwxyz')
for i in range(len(lis)):
lis.insert(i, lis.pop())
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
input(' 遍历数组所有元素 '.center(42, '~'))
# for 1/2,奇数个元素数组
lis = list('abcdefghijklmnopqrstuvwxy')
n = int(len(lis)/2) # 计算中间位置。
for i in range(1, n+1):
print(lis[n-i], lis[n+i])
lis[n-i], lis[n+i] = lis[n+i], lis[n-i]
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
input(' 遍历数组1/2元素(总元素为奇数) '.center(38, '~'))
# for all,偶数个元素数组。
lis = list('abcdefghijklmnopqrstuvwxyz')
n = int(len(lis)/2) - 1 # 计算中间位置。
for i in range(n+1):
print(lis[n-i], lis[n+i+1])
lis[n-i], lis[n+i+1] = lis[n+i+1], lis[n-i]
print(f"\n\n序列:{lis}\n\n反序:{lis}\n")
input(' 遍历数组1/2元素(总元素为偶数) '.center(38, '~'))
# 新生成列表,负步长切片。
lis = list('abcdefghijklmnopqrstuvwxyz')
print(f"\n\n序列:{lis}\n\n反序:{lis[::-1]}\n")
input(' 负步长切片 '.center(45, '~'))
# 新生成列表,resersed()。
lis = list('abcdefghijklmnopqrstuvwxyz')
print(f"\n返回类型:{type(reversed(lis))}\n")
print(f"\n\n序列:{lis}\n\n反序:{list(reversed(lis))}\n")
input(' reversed()函数 '.center(48, '~'))
# 新生成列表,storted()。
lis = list('abcdefghijklmnopqrstuvwxyz')
print(f"\n返回类型:{type(sorted(lis, reverse=True))}\n")
print(f"\n\n序列:{lis}\n\n反序:{sorted(lis, reverse=True)}\n")
input(' sorted()函数 '.center(48, '~'))
__上一篇:__ 代码实现“约瑟夫环”百科词条中的例子故事
__下一篇:__
我的HOT博:
- Hot:Python之魔幻切片(1207阅读)
- 练习:数列求和a, aa, aaa, ..., aa...aa(n个a)(1206阅读)
- 个人信息提取(1501阅读)
- 十六进制字符串转Python代码(utf-8字符串转十六进制字符串)(1025阅读)
- 生成100个随机正整数(1654阅读)
- 给定字符串提取姓名(字符串、list、re“零宽断言”)(1244阅读)
- 我的 Python.color() (Python 色彩打印控制)(1575阅读)
- python清屏(2416阅读)
- 回车符、换行符和回车换行符(2475阅读)
- Linux 脚本文件第一行的特殊注释符(井号和感叹号组合)的含义(1481阅读)
- random.sample()将在python 3.9x后续版本中被弃用(1346阅读)
- pandas 数据类型之 Series(1507阅读)
- 聊天消息敏感词屏蔽系统(字符串替换 str.replace(str1, *) )(1559阅读)
- 练习:银行复利计算(用 for 循环解一道初中小题)(1494阅读)
- pandas 数据类型之 DataFrame(3503阅读)
- :班里有人和我同生日难吗?(蒙特卡洛随机模拟法)(2298阅读)
- Python 续行符(\)“拯救”你的超长语句(1105阅读)
- Python字符串居中显示(3663阅读)
- 练习:求偶数和、阈值分割和求差( list 对象的两个基础小题)(1715阅读)
- 用 pandas 解一道小题(2083阅读)
- 可迭代对象和四个函数(1128阅读)
- “快乐数”判断(1299阅读)
- 罗马数字转换器(构造元素取模)(2392阅读)
- Hot:罗马数字(转换器|罗生成器)(5256阅读)
- Hot:让QQ群昵称色变的代码(44638阅读)
- Hot:斐波那契数列(递归| for )(4169阅读)
- 柱状图中最大矩形(1698阅读)
- 排序数组元素的重复起止(1299阅读)
- 电话拨号键盘字母组合(1485阅读)
- 密码强度检测器(22227阅读)
- 求列表平衡点(1891阅读)
- Hot: 字符串统计(4362阅读)
- Hot:尼姆游戏(聪明版首发)(3583阅读)
- 尼姆游戏(优化版)(1258阅读)
-
推荐条件 点阅破千
回页首
精品文章:
- 好文力荐:齐伟书稿 《python 完全自学教程》 Free连载(已完稿并集结成书,还有PDF版本百度网盘永久分享,点击跳转免费🆓下载。)
- OPP三大特性:封装中的property
- 通过内置对象理解python'
- 正则表达式
- python中“*”的作用
- Python 完全自学手册
- 海象运算符
- Python中的 `!=`与`is not`不同
- 学习编程的正确方法
来源:老齐教室
回页首
◆ Python 入门指南【Python 3.6.3】
好文力荐:
-
全栈领域优质创作者——寒佬(还是国内某高校学生)博文“非技术文—关于英语和如何正确的提问”,“英语”和“会提问”是学习的两大利器。
-
【8大编程语言的适用领域】先别着急选语言学编程,先看它们能干嘛
-
靠谱程序员的好习惯文章来源:https://www.toymoban.com/news/detail-452361.html
CSDN实用技巧博文:文章来源地址https://www.toymoban.com/news/detail-452361.html
- 8个好用到爆的Python实用技巧
- python忽略警告
- Python代码编写规范
- Python的docstring规范(说明文档的规范写法)
到了这里,关于Python列表(list)反序(降序)的7种实现方式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!