iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python列表(list)反序(降序)的7种实现方式
  • 161
分享到

Python列表(list)反序(降序)的7种实现方式

算法python 2023-10-26 20:10:47 161人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

python列表(list)反序(降序)的实现方式:原址反序,list.reverse()、list.sort()、全数组遍历、1/2数组遍历;新生成列表,resersed()、sorted

python列表(list)反序(降序)的实现方式:原址反序,list.reverse()、list.sort()、全数组遍历、1/2数组遍历;新生成列表,resersed()、sorted()、负步长切片[::-1]。共七种方式,可以实现列表反序。


(本文获得CSDN质量评分【91】)

学习的细节是欢悦的历程】

  • Python 官网https://www.python.org/" target="_blank" title="这里,才 python 前沿。可惜是英文原版。所以,我要练习英文阅读。🧐🧐" rel="noopener noreferrer">https://www.python.org/

  • Free:大咖免费“圣经教程 python 完全自学教程,不仅仅是基础那么简单……


  自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
            —— 华罗庚


等风来,不如追风去……


Python列表原址操作、新生成列表
列表反序的7种实现方式
(列表原址操作4种、新生成列表3种,共计7种)


本文质量分:

91
本文地址: https://blog.csdn.net/m0_57158496/article/details/128271700

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")

返回类型:

序列:[‘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")

返回类型:

序列:[‘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 alllis = 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博:

    来源地址:https://blog.csdn.net/m0_57158496/article/details/128271700

    --结束END--

    本文标题: Python列表(list)反序(降序)的7种实现方式

    本文链接: https://www.lsjlt.com/news/470744.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作