close

快速排序法(Quick sort)運用到 Divide and conquer 的概念,

把數列一分為二,最終完成排序。

 

步驟為:

1.  取第一個元素(最左的數)為鍵值 key

 

2.  由左向右(前向後)找一個數(第一個滿足的),

其值大於等於 key 值,該數之索引為 left_pivot

 

3.  由右向左(後向前)找一個數(第一個滿足的),

其值小於等於 key 值,該數之索引為 right_pivot

 

4.  如果 left_pivot < right_pivot 則交換值,

否則把 key 值與 right_pivot 值交換,以 right_pivot 為基準,分為左右兩個數列

 

5. 重複上述步驟排序左右兩個數列,直到完成排序

 

如下圖

quick.png

以下為Python的快速排序法(由小到大)程式碼

(使用了額外空間)

 

 

 

In-place的版本

 


參考wikipedia,https://zh.wikipedia.org/wiki/%E5%BF%AB%E9%80%9F%E6%8E%92%E5%BA%8F

快速排序可以參考wikipedia上的python超簡短的實作程式碼唷 =)

arrow
arrow
    文章標籤
    sort python 資料結構
    全站熱搜
    創作者介紹
    創作者 Jialin 的頭像
    Jialin

    Jialin

    Jialin 發表在 痞客邦 留言(2) 人氣()