Python快速排序算法實(shí)例分析
本文實(shí)例講述了Python快速排序算法。分享給大家供大家參考,具體如下:
快速排序的時(shí)間復(fù)雜度是O(NlogN)
算法描述:
① 先從序列中取出一個(gè)數(shù)作為基準(zhǔn)數(shù)
② 分區(qū)過程, 將比這個(gè)數(shù)大的數(shù)全部放到它的右邊, 小于或等于它的數(shù)全部放到它的左邊
③ 再對左右區(qū)間重復(fù)第二步, 直到各區(qū)間只有一個(gè)數(shù)
假設(shè)對 6, 1, 2, 7, 9, 3, 4, 5, 10, 8 進(jìn)行排序, 首先在這個(gè)序列中隨便找一個(gè)基準(zhǔn)數(shù)(用來參照), 比如選擇 6 為基準(zhǔn)數(shù), 接下來把所有比基準(zhǔn)數(shù)大的數(shù)放在6的右邊, 比6小的數(shù)放在左邊
原理分析:
① 選擇最左邊的數(shù)為基準(zhǔn)數(shù)key
② 設(shè)立兩個(gè)游標(biāo) low 和 high , 分別指向數(shù)組的最低位和最高位
③ 然后high先動(dòng), 如果high位上的數(shù)比key大, 則向前走, 如果high-1位上的數(shù)比key大, 繼續(xù)向前走, 直到該位上的數(shù)<=key
④ 此時(shí)比較low位, 如果<=key, low向后走, 變?yōu)閘ow+1, 依次類推, 直到該位上的數(shù)比key大
⑤ 交換high和low位上的數(shù)
⑥ 重復(fù)以上步驟, 直到low=high , 交換 key 和 high 位上的值
⑦ 最后進(jìn)行遞歸操作
示例代碼:
#!/usr/bin/env python
# coding:utf-8
# 設(shè)置最低位和最高位
def quickSort(nums, low, high):
# 設(shè)置一個(gè)比較基準(zhǔn)key
key = nums[low]
while low<high:
# 如果最高位的數(shù) 大于等于 key則向前走
while low<high and nums[high] >= key:
high -= 1
# 如果最低位的數(shù) 小于等于 key則向后走
while low<high and nums[low] <= key:
low += 1
# 交換值
nums[low], nums[high] = nums[high], nums[low]
#最后low=high, 此時(shí)交換key和high位上的值, 使小于key的值在key左邊, 大的在key右邊
nums[nums.index(key)], nums[low] = nums[low], nums[nums.index(key)]
# 返回最低位的位置
return low
# 進(jìn)行重復(fù)操作
def interval(nums, low, high):
if low<high:
# 進(jìn)行排序并得到最低位位置以循環(huán)操作
key_index = quickSort(nums, low, high)
interval(nums, low, key_index)
interval(nums, key_index+1, high)
nums = [64,3,9,2,4,7,0,12,45,]
interval(nums, 0, len(nums)-1)
print "腳本之家測試結(jié)果:"
print nums
"""
[0, 2, 3, 4, 7, 9, 12, 45, 64]
"""
運(yùn)行結(jié)果:

PS:關(guān)于排序算法的詳細(xì)說明還可參考本站在線工具:
在線動(dòng)畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具
http://tools.jb51.net/aideddesign/paixu_ys
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
- Python實(shí)現(xiàn)的快速排序算法詳解
- 快速排序的算法思想及Python版快速排序的實(shí)現(xiàn)示例
- Python實(shí)現(xiàn)快速排序算法及去重的快速排序的簡單示例
- Python實(shí)現(xiàn)快速排序和插入排序算法及自定義排序的示例
- javascript與Python快速排序?qū)嵗龑Ρ?/a>
- Python實(shí)現(xiàn)的數(shù)據(jù)結(jié)構(gòu)與算法之快速排序詳解
- python快速排序代碼實(shí)例
- python 算法 排序?qū)崿F(xiàn)快速排序
- python 快速排序代碼
- 快速排序的四種python實(shí)現(xiàn)(推薦)
相關(guān)文章
使用Python腳本對GiteePages進(jìn)行一鍵部署的使用說明
剛好之前有了解過python的自動(dòng)化,就想著自動(dòng)化腳本,百度一搜還真有類似的文章。今天就給大家分享下使用Python腳本對GiteePages進(jìn)行一鍵部署的使用說明,感興趣的朋友一起看看吧2021-05-05
利用Jmeter實(shí)現(xiàn)在請求param和body里面加入隨機(jī)參數(shù)
本文介紹了如何使用jemeter實(shí)現(xiàn)新增接口壓力測試中的隨機(jī)參數(shù)生成,首先,使用函數(shù)助手對話框生成隨機(jī)數(shù),然后將生成的隨機(jī)數(shù)作為參數(shù)放入請求中,無論請求格式是json、xml還是text等,如果param和body同時(shí)存在并需要隨機(jī)生成參數(shù),可以把參數(shù)寫入到請求地址中2024-10-10
Python如何生成隨機(jī)數(shù)及random隨機(jī)數(shù)模塊應(yīng)用
這篇文章主要介紹了Python如何生成隨機(jī)數(shù)及random隨機(jī)數(shù)模塊應(yīng)用,首先我們要知道在python中用于生成隨機(jī)數(shù)的模塊是random,在使用前需要import。由此展開內(nèi)容介紹,需要的小伙伴可以參考一下2022-06-06
python topN 取最大的N個(gè)數(shù)或最小的N個(gè)數(shù)方法
今天小編就為大家分享一篇python topN 取最大的N個(gè)數(shù)或最小的N個(gè)數(shù)方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06
python 遺傳算法求函數(shù)極值的實(shí)現(xiàn)代碼
今天小編就為大家分享一篇python 遺傳算法求函數(shù)極值的實(shí)現(xiàn)代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02
基于python實(shí)現(xiàn)模擬數(shù)據(jù)結(jié)構(gòu)模型
這篇文章主要介紹了基于python實(shí)現(xiàn)模擬數(shù)據(jù)結(jié)構(gòu)模型,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06
Python 多線程共享變量的實(shí)現(xiàn)示例
這篇文章主要介紹了Python 多線程共享變量的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
python selenium禁止加載某些請求的實(shí)現(xiàn)
本文主要介紹了python selenium禁止加載某些請求的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01

