笔者在做算法题目时候需要对列表中的列表(元素是列表,列表中有两个元素)进行排序。如何实现按照第一个元素降序,第二个元素排序?
例如:对list0进行排序,实现res的结果!
list0 = [[7, 0], [4, 4], [7, 1], [5, 0], [6, 1], [5, 2]]
res = [[7, 0], [7, 1], [6, 1], [5, 0], [5, 2], [4, 4]]
查询博客发现可以使用sort()函数进行,设置key=lambda x: (-x[0], x[1])就可以了,顺便复习一下python中sort()函数的使用。
1. sort()函数,实现列表的升序和逆序排序
# 1. sort()函数
# sort()是对列表中的元素进行排序,默认按第一个元素升序,第二个元素升序
# sort()原位操作,返回值为None
>>> list0 = [[7, 0], [4, 4], [7, 1], [5, 0], [6, 1], [5, 2]]
>>> list1 = list0.sort()
>>> print("list0.sort()的返回值:", list1)
list0.sort()的返回值: None
>>> print("list0:", list0)
list0: [[4, 4], [5, 0], [5, 2], [6, 1], [7, 0], [7, 1]]
# # 2 sort()函数的逆序,,默认按第一个元素降序,第二个元素降序
# list0.sort(reverse=True)
# print("list0的逆序排序", list0)
>>> list0 = [[7, 0], [4, 4], [7, 1], [5, 0], [6, 1], [5, 2]]
>>> list0.sort(reverse=True)
>>> list0
[[7, 1], [7, 0], [6, 1], [5, 2], [5, 0], [4, 4]]
>>> print("list0的逆序排序", list0)
list0的逆序排序 [[7, 1], [7, 0], [6, 1], [5, 2], [5, 0], [4, 4]]
2. sorted()实现按照第一个元素降序,第二个元素排序?
# 3. sorted()函数,返回排序之后的值,原来的排序数组不变
# sorted()函数,默认按第一个元素升序,第二个元素升序
>>> list0 = [[7, 0], [4, 4], [7, 1], [5, 0], [6, 1], [5, 2]]
>>> list2 = sorted(list0)
>>> print("list2:", list2)
list2: [[4, 4], [5, 0], [5, 2], [6, 1], [7, 0], [7, 1]]
>>> print("list0:", list0)
list0: [[7, 0], [4, 4], [7, 1], [5, 0], [6, 1], [5, 2]]
# 4. sorted()函数,按第一个元素降序,按第二个元素升序(第一个元素相同的时候,按第二个元素小的排在前面)
>>> list3 = sorted(list0, key=lambda x: (-x[0], x[1]))
>>> print("list3:", list3)
list3: [[7, 0], [7, 1], [6, 1], [5, 0], [5, 2], [4, 4]]
see you~