Python實(shí)現(xiàn)的計(jì)數(shù)排序算法示例
本文實(shí)例講述了Python實(shí)現(xiàn)的計(jì)數(shù)排序算法。分享給大家供大家參考,具體如下:
計(jì)數(shù)排序是一種非??旖莸姆€(wěn)定性強(qiáng)的排序方法,時(shí)間復(fù)雜度O(n+k),其中n為要排序的數(shù)的個(gè)數(shù),k為要排序的數(shù)的組大值。計(jì)數(shù)排序?qū)σ欢康恼麛?shù)排序時(shí)候的速度非???,一般快于其他排序算法。但計(jì)數(shù)排序局限性比較大,只限于對整數(shù)進(jìn)行排序。計(jì)數(shù)排序是消耗空間發(fā)雜度來獲取快捷的排序方法,其空間發(fā)展度為O(K)同理K為要排序的最大值。
計(jì)數(shù)排序的基本思想為一組數(shù)在排序之前先統(tǒng)計(jì)這組數(shù)中其他數(shù)小于這個(gè)數(shù)的個(gè)數(shù),則可以確定這個(gè)數(shù)的位置。例如要排序的數(shù)為 7 4 2 1 5 3 1 5;則比7小的有7個(gè)數(shù),所有7應(yīng)該在排序好的數(shù)列的第八位,同理3在第四位,對于重復(fù)的數(shù)字,1在1位和2位(暫且認(rèn)為第一個(gè)1比第二個(gè)1?。?,5和1一樣位于6位和7位。
示例代碼:
#! /usr/bin/env python #coding=utf-8 #計(jì)數(shù)排序 def CountingSort(a, b, k): #c=[0]*(k+1) #let c[0...k] be an all 0 array #c=[0 for i in range(0,k+1)] c=[] for i in range(k+1): c.append(0) for j in range(len(a)): c[a[j]] = c[a[j]] + 1 for i in range(1, k+1): c[i] = c[i] + c[i-1] for j in range(len(a)-1, -1, -1): b[c[a[j]]-1] = a[j]#!!!!!減一是關(guān)鍵 c[a[j]] = c[a[j]] - 1 print b if __name__ == '__main__': a=[2, 5, 3, 0, 2, 3, 0, 3] #b=[0]*len(a) b=[None for i in range(len(a))] print "腳本之家測試結(jié)果:" CountingSort(a, b, max(a))
運(yùn)行結(jié)果:
PS:關(guān)于排序算法的詳細(xì)說明還可參考本站在線工具:
在線動畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具
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ì)有所幫助。
相關(guān)文章
python+OpenCV人臉識別考勤系統(tǒng)實(shí)現(xiàn)的詳細(xì)代碼
作為一個(gè)基于人臉識別算法的考勤系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)教程,以下內(nèi)容將提供詳細(xì)的步驟和代碼示例。本教程將使用 Python 語言和 OpenCV 庫進(jìn)行實(shí)現(xiàn),需要的朋友可以參考下2023-05-05解決Pymongo insert時(shí)會自動添加_id的問題
這篇文章主要介紹了解決Pymongo insert時(shí)會自動添加_id的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12python使用rstrip函數(shù)刪除字符串末位字符
rstrip函數(shù)用于刪除字符串末位指定字符,默認(rèn)為空白符,這篇文章主要介紹了python使用rstrip函數(shù)刪除字符串末位字符的方法,需要的朋友可以參考下2023-04-04使用PySpider進(jìn)行IP代理爬蟲的技巧與實(shí)踐分享
PySpider是一個(gè)基于Python的強(qiáng)大的開源網(wǎng)絡(luò)爬蟲框架,它使用簡單、靈活,并且具有良好的擴(kuò)展性,本文將介紹如何使用PySpider進(jìn)行IP代理爬蟲,并提供一些技巧和實(shí)踐經(jīng)驗(yàn),文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下2024-03-03Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用示例
這篇文章主要介紹了Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用,結(jié)合實(shí)例形式分析了Python數(shù)據(jù)結(jié)構(gòu)中圖的定義與遍歷算法相關(guān)操作技巧,需要的朋友可以參考下2018-05-05python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動畫
這篇文章主要為大家詳細(xì)介紹了python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動畫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04