Python實現(xiàn)的計數(shù)排序算法示例
本文實例講述了Python實現(xiàn)的計數(shù)排序算法。分享給大家供大家參考,具體如下:
計數(shù)排序是一種非??旖莸姆€(wěn)定性強的排序方法,時間復(fù)雜度O(n+k),其中n為要排序的數(shù)的個數(shù),k為要排序的數(shù)的組大值。計數(shù)排序?qū)σ欢康恼麛?shù)排序時候的速度非???,一般快于其他排序算法。但計數(shù)排序局限性比較大,只限于對整數(shù)進行排序。計數(shù)排序是消耗空間發(fā)雜度來獲取快捷的排序方法,其空間發(fā)展度為O(K)同理K為要排序的最大值。
計數(shù)排序的基本思想為一組數(shù)在排序之前先統(tǒng)計這組數(shù)中其他數(shù)小于這個數(shù)的個數(shù),則可以確定這個數(shù)的位置。例如要排序的數(shù)為 7 4 2 1 5 3 1 5;則比7小的有7個數(shù),所有7應(yīng)該在排序好的數(shù)列的第八位,同理3在第四位,對于重復(fù)的數(shù)字,1在1位和2位(暫且認為第一個1比第二個1?。?和1一樣位于6位和7位。
示例代碼:
#! /usr/bin/env python
#coding=utf-8
#計數(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))
運行結(jié)果:

PS:關(guān)于排序算法的詳細說明還可參考本站在線工具:
在線動畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具
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īng)典教程》
希望本文所述對大家Python程序設(shè)計有所幫助。
相關(guān)文章
python+OpenCV人臉識別考勤系統(tǒng)實現(xiàn)的詳細代碼
作為一個基于人臉識別算法的考勤系統(tǒng)的設(shè)計與實現(xiàn)教程,以下內(nèi)容將提供詳細的步驟和代碼示例。本教程將使用 Python 語言和 OpenCV 庫進行實現(xiàn),需要的朋友可以參考下2023-05-05
python使用rstrip函數(shù)刪除字符串末位字符
rstrip函數(shù)用于刪除字符串末位指定字符,默認為空白符,這篇文章主要介紹了python使用rstrip函數(shù)刪除字符串末位字符的方法,需要的朋友可以參考下2023-04-04
Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用示例
這篇文章主要介紹了Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用,結(jié)合實例形式分析了Python數(shù)據(jù)結(jié)構(gòu)中圖的定義與遍歷算法相關(guān)操作技巧,需要的朋友可以參考下2018-05-05
python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動畫
這篇文章主要為大家詳細介紹了python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動畫,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-04-04

