list.sort()和函数sorted(list)

sort()是列表的方法,修改原列表使得它按照大小排序,没有返回值,返回None

In [90]: x = [4, 6, 2, 1, 7, 9]

In [91]: x.sort()

In [92]: x
Out[92]: [1, 2, 4, 6, 7, 9]
In [98]: aa = x.sort()
In [99]: aa #  返回None

sorted()是函数,不改变列表,重新生成一个按大小排序的列表

In [94]: a = sorted(x)
In [95]: a
Out[95]: [1, 2, 4, 6, 7, 9]

In [96]: x
Out[96]: [4, 6, 2, 1, 7, 9]

三、可选参数 列表sort方法还有两个可选参数:key和reverse

## 1、key在使用时必须提供一个排序过程总调用的函数:
x = ['mmm', 'mm', 'mm', 'm']
x.sort(key=len)
print(x)  # 输出 ['m', 'mm', 'mm', 'mmm']

## 2、reverse实现降序排序,需要提供一个布尔值:
y = [3, 2, 8, 0, 1]
y.sort(reverse=True)
print(y)  # [8, 3, 2, 1, 0]

权重排序(具体的我也不太懂)

def sort_priority(values,group):
    def helper(x):
        if x in group:
            print('在group',0,x)
            return (0,x)
            # print(values)
        print('不在group',1,x)
        return (1,x)
    values.sort(key=helper)
    # values.sort()

numbers = [8,3,1,2,5,4,7,6]
group = {2,3,5,7}
sort_priority(numbers,group)
print(numbers)
输出:
不在group 1 8
在group 0 3
不在group 1 1
在group 0 2
在group 0 5
不在group 1 4
在group 0 7
不在group 1 6
[2, 3, 5, 7, 1, 4, 6, 8]
上一篇:【leetcode】高频题目整理_链表篇( High Frequency Problems, Linked List )


下一篇:python sorted函数的使用