Python實(shí)現(xiàn)的快速排序算法詳解
本文實(shí)例講述了Python實(shí)現(xiàn)的快速排序算法。分享給大家供大家參考,具體如下:
快速排序基本思想是:通過(guò)一趟排序?qū)⒁判虻臄?shù)據(jù)分割成獨(dú)立的兩部分,其中一部分的所有數(shù)據(jù)都比另外一部分的所有數(shù)據(jù)都要小,然后再按此方法對(duì)這兩部分?jǐn)?shù)據(jù)分別進(jìn)行快速排序,整個(gè)排序過(guò)程可以遞歸進(jìn)行,以此達(dá)到整個(gè)數(shù)據(jù)變成有序序列。
如序列[6,8,1,4,3,9],選擇6作為基準(zhǔn)數(shù)。從右向左掃描,尋找比基準(zhǔn)數(shù)小的數(shù)字為3,交換6和3的位置,[3,8,1,4,6,9],接著從左向右掃描,尋找比基準(zhǔn)數(shù)大的數(shù)字為8,交換6和8的位置,[3,6,1,4,8,9]。重復(fù)上述過(guò)程,直到基準(zhǔn)數(shù)左邊的數(shù)字都比其小,右邊的數(shù)字都比其大。然后分別對(duì)基準(zhǔn)數(shù)左邊和右邊的序列遞歸進(jìn)行上述方法。
實(shí)現(xiàn)代碼如下:
def parttion(v, left, right): key = v[left] low = left high = right while low < high: while (low < high) and (v[high] >= key): high -= 1 v[low] = v[high] while (low < high) and (v[low] <= key): low += 1 v[high] = v[low] v[low] = key return low def quicksort(v, left, right): if left < right: p = parttion(v, left, right) quicksort(v, left, p-1) quicksort(v, p+1, right) return v s = [6, 8, 1, 4, 3, 9, 5, 4, 11, 2, 2, 15, 6] print("before sort:",s) s1 = quicksort(s, left = 0, right = len(s) - 1) print("after sort:",s1)
運(yùn)行結(jié)果:
before sort: [6, 8, 1, 4, 3, 9, 5, 4, 11, 2, 2, 15, 6] after sort: [1, 2, 2, 3, 4, 4, 5, 6, 6, 8, 9, 11, 15]
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門(mén)與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- Python快速排序算法實(shí)例分析
- 快速排序的算法思想及Python版快速排序的實(shí)現(xiàn)示例
- Python實(shí)現(xiàn)快速排序算法及去重的快速排序的簡(jiǎn)單示例
- Python實(shí)現(xiàn)快速排序和插入排序算法及自定義排序的示例
- javascript與Python快速排序?qū)嵗龑?duì)比
- Python實(shí)現(xiàn)的數(shù)據(jù)結(jié)構(gòu)與算法之快速排序詳解
- python快速排序代碼實(shí)例
- python 算法 排序?qū)崿F(xiàn)快速排序
- python 快速排序代碼
- 快速排序的四種python實(shí)現(xiàn)(推薦)
相關(guān)文章
用 Django 開(kāi)發(fā)一個(gè) Python Web API的方法步驟
這篇文章主要介紹了用 Django 開(kāi)發(fā)一個(gè) Python Web API的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12解決tensorflow測(cè)試模型時(shí)NotFoundError錯(cuò)誤的問(wèn)題
今天小編就為大家分享一篇解決tensorflow測(cè)試模型時(shí)NotFoundError錯(cuò)誤的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07Python爬蟲(chóng)獲取豆瓣電影并寫(xiě)入excel
這篇文章主要介紹了Python爬蟲(chóng)獲取豆瓣電影并寫(xiě)入excel ,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07python如何利用cv2.rectangle()繪制矩形框
cv2.rectangle這個(gè)函數(shù)的作用是在圖像上繪制一個(gè)簡(jiǎn)單的矩形,下面這篇文章主要給大家介紹了關(guān)于python如何利用cv2.rectangle()繪制矩形框的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-12-12