Python中的sort()函数是一种非常常用的排序函数,它可以对列表、元组等可迭代对象进行排序。sort()函数有两种排序方式:升序和降序。默认情况下,sort()函数使用升序排列。sort()函数的语法如下所示:
`python
_x000D_list.sort(key=None, reverse=False)
_x000D_ _x000D_其中,key参数表示用于排序的函数,reverse参数表示是否降序排列。如果reverse参数为True,那么sort()函数将按照降序排列。如果reverse参数为False或者不指定,那么sort()函数将按照升序排列。
_x000D_下面我们来详细了解一下sort()函数的用法。
_x000D_## sort()函数的基本用法
_x000D_sort()函数的基本用法非常简单。我们只需要调用列表的sort()方法即可对列表进行排序。例如:
_x000D_`python
_x000D_numbers = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
_x000D_numbers.sort()
_x000D_print(numbers)
_x000D_ _x000D_输出结果为:
_x000D_ _x000D_[1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]
_x000D_ _x000D_sort()函数默认按照升序排列。如果我们想按照降序排列,只需要将reverse参数设置为True即可。例如:
_x000D_`python
_x000D_numbers = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
_x000D_numbers.sort(reverse=True)
_x000D_print(numbers)
_x000D_ _x000D_输出结果为:
_x000D_ _x000D_[9, 6, 5, 5, 5, 4, 3, 3, 2, 1, 1]
_x000D_ _x000D_## sort()函数的高级用法
_x000D_除了基本用法之外,sort()函数还有一些高级用法。下面我们来一一介绍。
_x000D_### 用key参数进行排序
_x000D_sort()函数的key参数可以指定一个函数,用于指定排序的规则。例如,我们可以使用key参数按照字符串长度进行排序。例如:
_x000D_`python
_x000D_fruits = ['banana', 'apple', 'pear', 'orange', 'kiwi']
_x000D_fruits.sort(key=len)
_x000D_print(fruits)
_x000D_ _x000D_输出结果为:
_x000D_ _x000D_['pear', 'kiwi', 'apple', 'banana', 'orange']
_x000D_ _x000D_在上面的例子中,我们使用了len()函数作为key参数,sort()函数按照字符串长度进行排序。
_x000D_### 用lambda函数进行排序
_x000D_除了使用普通函数之外,我们还可以使用lambda函数来指定排序规则。例如,我们可以使用lambda函数按照字符串的第二个字符进行排序。例如:
_x000D_`python
_x000D_fruits = ['banana', 'apple', 'pear', 'orange', 'kiwi']
_x000D_fruits.sort(key=lambda x: x[1])
_x000D_print(fruits)
_x000D_ _x000D_输出结果为:
_x000D_ _x000D_['banana', 'kiwi', 'orange', 'apple', 'pear']
_x000D_ _x000D_在上面的例子中,我们使用了lambda函数作为key参数,sort()函数按照字符串的第二个字符进行排序。
_x000D_### 对元组进行排序
_x000D_sort()函数不仅可以对列表进行排序,还可以对元组进行排序。例如,我们可以使用sort()函数对元组进行排序。例如:
_x000D_`python
_x000D_students = [('Tom', 80), ('Jerry', 90), ('Mike', 70), ('John', 85)]
_x000D_students.sort(key=lambda x: x[1], reverse=True)
_x000D_print(students)
_x000D_ _x000D_输出结果为:
_x000D_ _x000D_[('Jerry', 90), ('John', 85), ('Tom', 80), ('Mike', 70)]
_x000D_ _x000D_在上面的例子中,我们使用了lambda函数作为key参数,sort()函数按照元组的第二个元素进行排序。
_x000D_## sort()函数的相关问答
_x000D_### sort()函数和sorted()函数有什么区别?
_x000D_sort()函数和sorted()函数都可以用来对列表进行排序。它们的区别在于,sort()函数是列表的一个方法,它会直接修改原来的列表,而sorted()函数是一个内置函数,它会返回一个新的有序列表,不会修改原来的列表。
_x000D_### sort()函数和sorted()函数的时间复杂度是多少?
_x000D_sort()函数和sorted()函数的时间复杂度都是O(nlogn)。
_x000D_### sort()函数的稳定性是什么?
_x000D_sort()函数是稳定的。稳定性指的是,如果两个元素的值相等,它们在排序后的相对位置不会改变。
_x000D_### sort()函数可以对任何可迭代对象进行排序吗?
_x000D_sort()函数只能对可变序列进行排序,例如列表。对于不可变序列,例如元组,sort()函数是不支持的。
_x000D_