快速排序的四種python實現
轉自:https://blog.csdn.net/razor87/article/details/71155518
快速排序演算法,簡稱快排,是最實用的排序演算法,沒有之一,各大語言標準庫的排序函式也基本都是基於快排實現的。
本文用python語言介紹四種不同的快排實現。
1. 一行程式碼實現的簡潔版本
quick_sort = lambda array: array if len(array) <= 1 else quick_sort([item for item in array[1:] if item <= array[0]]) + [array[0]] + quick_sort([item for item in array[1:] if item > array[0]])
2. 網上常見的快排實現
def quick_sort(array, left, right):
if left >= right:
return
low = left
high = right
key = array[low]
while left < right:
while left < right and array[right] > key:
right -= 1
array[left] = array[right]
while left < right and array[left] <= key:
left += 1
array[right] = array[left]
array[right] = key
quick_sort(array, low, left - 1)
quick_sort(array, left + 1, high)
由於快排是原地排序,因此不需要返回array。
array如果是個列表的話,可以通過len(array)求得長度,但是後邊遞迴呼叫的時候必須使用分片,而分片執行的原列表的複製操作,這樣就達不到原地排序的目的了,所以還是要傳上邊界和下邊界的。
3.《演算法導論》中的快排程式
def quick_sort(array, l, r):
if l < r:
q = partition(array, l, r)
quick_sort(array, l, q - 1)
quick_sort(array, q + 1, r)
def partition(array, l, r):
x = array[r]
i = l - 1
for j in range(l, r):
if array[j] <= x:
i += 1
array[i], array[j] = array[j], array[i]
array[i + 1], array[r] = array[r], array[i+1]
return i + 1
這個版本跟上個版本的不同在於分片過程不同,只用了一層迴圈,並且一趟就完成分片,相比之下程式碼要簡潔的多了。
4. 用棧實現非遞迴的快排程式
先說兩句題外話,一般意義上的棧有兩層含義,一層是後進先出的資料結構棧,一層是指函式的記憶體棧,歸根結底,函式的記憶體棧的結構就是一個後進先出的棧。彙編程式碼中,呼叫一個函式的時候,修改的也是堆疊指標暫存器ESP,該暫存器儲存的是函式區域性棧的棧頂,另外一個暫存器EBP儲存的是棧底。不知道與棧儲存空間相對的堆儲存空間,其組織結構是否也是一個完全二叉樹呢?
高階語言將遞迴轉換為迭代,用的也是棧,需要考慮兩個問題:
1)棧裡邊儲存什麼?
2)迭代結束的條件是什麼?
棧裡邊儲存的當然是需要迭代的函式引數,結束條件也是跟需要迭代的引數有關。對於快速排序來說,迭代的引數是陣列的上邊界low和下邊界high,迭代結束的條件是low == high。
def quick_sort(array, l, r):
if l >= r:
return
stack = []
stack.append(l)
stack.append(r)
while stack:
low = stack.pop(0)
high = stack.pop(0)
if high - low <= 0:
continue
x = array[high]
i = low - 1
for j in range(low, high):
if array[j] <= x:
i += 1
array[i], array[j] = array[j], array[i]
array[i + 1], array[high] = array[high], array[i + 1]
stack.extend([low, i, i + 2, high])
另外,當陣列下標為-1時,C++、Java等語言中會報錯,但python中訪問的是最後一個元素,所以如果程式寫錯了,可能其他語言會報錯,但python會輸出一個錯誤的結果。
---------------------
作者:lookupheaven
來源:CSDN
原文:https://blog.csdn.net/razor87/article/details/71155518
版權宣告:本文為博主原創文章,轉載請附上博文連結!
相關文章
- 快速排序三種實現排序
- Python實現的快速排序Python排序
- python實現快速排序Python排序
- python排序演算法的實現-快速排序Python排序演算法
- 三種語言實現快速排序(C++/Python/Java)排序C++PythonJava
- 快速排序的三種實現方法 (C++)排序C++
- js實現兩種實用的排序演算法——冒泡、快速排序JS排序演算法
- Python3實現快速排序Python排序
- 快速理解7種排序演算法 | python3實現(排序演算法Python
- 快速排序的實現排序
- PHP實現四種基本排序演算法PHP排序演算法
- PHP 四種基本排序演算法的程式碼實現PHP排序演算法
- GO 實現快速排序Go排序
- 快速排序 java實現排序Java
- Swift實現快速排序Swift排序
- java實現快速排序Java排序
- 快速排序(java實現)排序Java
- 快速排序(Quicksort)的Javascript實現排序UIJavaScript
- python實現氣泡排序、插入排序以及快速排序演算法Python排序演算法
- 四、歸併排序 && 快速排序排序
- 排序演算法之快速排序的實現排序演算法
- php實現 歸併排序,快速排序PHP排序
- python實現常用五種排序演算法Python排序演算法
- 用 python 實現各種排序演算法Python排序演算法
- 三種快速排序排序
- python實現常見的五種排序演算法Python排序演算法
- Go實現氣泡排序和快速排序Go排序
- 快速掌握RabbitMQ(四)——兩種種消費模式和QOS的C#實現MQ模式C#
- JavaScript實現標準快速排序JavaScript排序
- 三種快速排序演算法以及快速排序的優化排序演算法優化
- O(lgn)的三種排序,快速排序、歸併排序、堆排序排序
- 三種快速排序法排序
- python 快速排序Python排序
- 歸併排序與快速排序的一個實現與理解排序
- python3實現幾種常見的排序演算法Python排序演算法
- 快速排序(quicksort)演算法實現排序UI演算法
- 歸併排序與快速排序的簡明實現及對比排序
- 排序演算法-Java實現快速排序演算法排序演算法Java