python列表排序函数

本文详细比较了Python中的sort()和sorted()方法,指出sort()会直接修改原列表,而sorted()返回新列表。讲解了cmp、key和reverse参数的作用,并通过示例展示了如何根据需求进行升序和降序排序,以及如何使用key进行复杂条件下的元素比较。
摘要由CSDN通过智能技术生成

sort和sorted方法:

二者都是用在list数据类型中的排序方法

区别是:

sorted没有修改原来的数组,而是将数组的结果作为参数传递给一个新的数组;

sort在原数组上直接进行排序,也就是会修改原数组。

 

list.sort(cmp=None, key=None, reverse=False)
sorted(iterable, cmp=None, key=None, reverse=False)

参数 :

cmp :可选参数, 如果指定了该参数会使用该参数的方法进行排序。
key :主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,            指定可迭代对象中的一个元素来进行排序。
reverse :排序规则,reverse = True 降序, reverse = False 升序(默认)。

示例:

reverse:

# sort()
lis = [1,5,4,7]
lis.sort() 
print(lis) # [1,4,5,7] 升序

lis = [1,5,4,7]
lis.sort(reverse = True)
print(lis) # [7,5,4,1] 降序
# sorted()
lis = [1,5,4,7]
sort_lis = sorted(lis)
print(sort_lis) # [1,4,5,7] 升序

lis = [1,5,4,7]
sort_lis = sorted(lis, reverse = True)
print(sort_lis) # [7,5,4,1] 降序

key:

# 获取列表的第二个元素
def sort_key(elem):
    return elem[1]

# 列表
random = [(2, 2), (3, 4), (4, 1), (1, 3)]
# random = [[2,2],[3,4],[4,1],[1,3]] 同理

# 指定第二个元素排序
random.sort(key=sort_key)
# random.sort(key = lambda item:item[1])  
 
print(random) # [(4, 1), (2, 2), (1, 3), (3, 4)]

示例:如果元组里第一个元素是奇数,就用元组里第一个元素进行排序,如果元组里第一个元素是偶数,则用这个元组里的第二个元组进行大小比较。

from functools import cmp_to_key
lst = [(9, 4), (2, 10), (4, 3), (3, 6)]

def cmp(x, y):
    a = x[0] if x[0] %2 == 1 else x[1]
    b = y[0] if y[0] %2 == 1 else y[1]

    return 1 if a > b else -1 if a < b else 0

lst.sort(key=cmp_to_key(cmp))
print(lst) # [(4, 3), (3, 6), (9, 4), (2, 10)]

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值