Python中的sort()函數(shù)是一種非常常用的排序函數(shù),它可以對列表、元組等可迭代對象進行排序。sort()函數(shù)有兩種排序方式:升序和降序。默認(rèn)情況下,sort()函數(shù)使用升序排列。sort()函數(shù)的語法如下所示:
_x000D_`python
_x000D_list.sort(key=None, reverse=False)
_x000D_ _x000D_其中,key參數(shù)表示用于排序的函數(shù),reverse參數(shù)表示是否降序排列。如果reverse參數(shù)為True,那么sort()函數(shù)將按照降序排列。如果reverse參數(shù)為False或者不指定,那么sort()函數(shù)將按照升序排列。
_x000D_下面我們來詳細(xì)了解一下sort()函數(shù)的用法。
_x000D_## sort()函數(shù)的基本用法
_x000D_sort()函數(shù)的基本用法非常簡單。我們只需要調(diào)用列表的sort()方法即可對列表進行排序。例如:
_x000D_`python
_x000D_numbers = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
_x000D_numbers.sort()
_x000D_print(numbers)
_x000D_ _x000D_輸出結(jié)果為:
_x000D_ _x000D_[1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]
_x000D_ _x000D_sort()函數(shù)默認(rèn)按照升序排列。如果我們想按照降序排列,只需要將reverse參數(shù)設(shè)置為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_輸出結(jié)果為:
_x000D_ _x000D_[9, 6, 5, 5, 5, 4, 3, 3, 2, 1, 1]
_x000D_ _x000D_## sort()函數(shù)的高級用法
_x000D_除了基本用法之外,sort()函數(shù)還有一些高級用法。下面我們來一一介紹。
_x000D_### 用key參數(shù)進行排序
_x000D_sort()函數(shù)的key參數(shù)可以指定一個函數(shù),用于指定排序的規(guī)則。例如,我們可以使用key參數(shù)按照字符串長度進行排序。例如:
_x000D_`python
_x000D_fruits = ['banana', 'apple', 'pear', 'orange', 'kiwi']
_x000D_fruits.sort(key=len)
_x000D_print(fruits)
_x000D_ _x000D_輸出結(jié)果為:
_x000D_ _x000D_['pear', 'kiwi', 'apple', 'banana', 'orange']
_x000D_ _x000D_在上面的例子中,我們使用了len()函數(shù)作為key參數(shù),sort()函數(shù)按照字符串長度進行排序。
_x000D_### 用lambda函數(shù)進行排序
_x000D_除了使用普通函數(shù)之外,我們還可以使用lambda函數(shù)來指定排序規(guī)則。例如,我們可以使用lambda函數(shù)按照字符串的第二個字符進行排序。例如:
_x000D_`python
_x000D_fruits = ['banana', 'apple', 'pear', 'orange', 'kiwi']
_x000D_fruits.sort(key=lambda x: x[1])
_x000D_print(fruits)
_x000D_ _x000D_輸出結(jié)果為:
_x000D_ _x000D_['banana', 'kiwi', 'orange', 'apple', 'pear']
_x000D_ _x000D_在上面的例子中,我們使用了lambda函數(shù)作為key參數(shù),sort()函數(shù)按照字符串的第二個字符進行排序。
_x000D_### 對元組進行排序
_x000D_sort()函數(shù)不僅可以對列表進行排序,還可以對元組進行排序。例如,我們可以使用sort()函數(shù)對元組進行排序。例如:
_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_輸出結(jié)果為:
_x000D_ _x000D_[('Jerry', 90), ('John', 85), ('Tom', 80), ('Mike', 70)]
_x000D_ _x000D_在上面的例子中,我們使用了lambda函數(shù)作為key參數(shù),sort()函數(shù)按照元組的第二個元素進行排序。
_x000D_## sort()函數(shù)的相關(guān)問答
_x000D_### sort()函數(shù)和sorted()函數(shù)有什么區(qū)別?
_x000D_sort()函數(shù)和sorted()函數(shù)都可以用來對列表進行排序。它們的區(qū)別在于,sort()函數(shù)是列表的一個方法,它會直接修改原來的列表,而sorted()函數(shù)是一個內(nèi)置函數(shù),它會返回一個新的有序列表,不會修改原來的列表。
_x000D_### sort()函數(shù)和sorted()函數(shù)的時間復(fù)雜度是多少?
_x000D_sort()函數(shù)和sorted()函數(shù)的時間復(fù)雜度都是O(nlogn)。
_x000D_### sort()函數(shù)的穩(wěn)定性是什么?
_x000D_sort()函數(shù)是穩(wěn)定的。穩(wěn)定性指的是,如果兩個元素的值相等,它們在排序后的相對位置不會改變。
_x000D_### sort()函數(shù)可以對任何可迭代對象進行排序嗎?
_x000D_sort()函數(shù)只能對可變序列進行排序,例如列表。對于不可變序列,例如元組,sort()函數(shù)是不支持的。
_x000D_