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_