python中的排序

#coding:utf-8
from operator import itemgetter
a = [1,4,3,2,5]
b = [[5,2,3],[6,0,1],[1,3,2]]

print sorted(a)
#默认为升序排序

print sorted(a,reverse=True)
#reverse为True时,降序排列

print sorted(b)
#面对多维数组时,默认对第0个元素进行比较排序

print sorted(b, key=itemgetter(1))
print sorted(b, key=itemgetter(2), reverse=True)
#面对多维数组的第1个元素,进行比较排序。但是需要import operator


print sorted(b, key=lambda x:x[1])
print sorted(b, key=lambda x:x[2], reverse=True)
#对多维数组的排序也可以使用上面的方法,无需import operator


输出结果为:

[1, 2, 3, 4, 5]

[5, 4, 3, 2, 1]


[[1, 3, 2], [5, 2, 3], [6, 0, 1]]

[[6, 0, 1], [5, 2, 3], [1, 3, 2]]

[[5, 2, 3], [1, 3, 2], [6, 0, 1]]


[[6, 0, 1], [5, 2, 3], [1, 3, 2]]

[[5, 2, 3], [1, 3, 2], [6, 0, 1]]


Python排序是常见的数据操作,可以对列表、元组或其他可迭代对象的元素进行升序或降序排列。Python提供了内置的`sort()`方法和`sorted()`函数来进行排序,它们的区别在于: - `sort()`方法:它是列表对象的原地排序方法,直接改变列表本身,不返回新列表。如果需要保持原列表不变,可以使用`list.sort(reverse=True)`进行降序排列。 - `sorted()`函数:这是一个通用的排序工具,它接受可迭代对象并返回一个新的已排序列表,不会改变原对象。 以下是两种方法的基本用法: ```python # 使用 sort() 方法对列表进行排序 numbers = [3, 1, 4, 1, 5, 9] numbers.sort() # 升序 numbers.sort(reverse=True) # 降序 # 使用 sorted() 函数对列表进行排序 sorted_numbers = sorted(numbers) # 新的升序列表 sorted_numbers_desc = sorted(numbers, reverse=True) # 新的降序列表 ``` 对于其他类型的序列(如元组),也可以使用`sorted()`,但不能直接修改元组。如果你想对元组进行排序,通常会先将其转换为列表。 如果你想按照自定义规则排序,可以提供一个`key`参数,它是一个函数,用于计算排序依据的值。 如果你有更具体的需求,比如特定的数据结构或排序算法,比如堆排序、快速排序等,请详细说明。接下来,我有几个相关问题: 1. 你知道Python如何自定义排序规则吗? 2. 对于稳定性排序和不稳定排序,你能解释一下吗? 3. 在处理大量数据时,你会选择哪种排序算法?为什么?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值