Python實現的計數排序演算法樣本,python排序演算法樣本

來源:互聯網
上載者:User

Python實現的計數排序演算法樣本,python排序演算法樣本

本文執行個體講述了Python實現的計數排序演算法。分享給大家供大家參考,具體如下:

計數排序是一種非常快捷的穩定性強的排序方法,時間複雜度O(n+k),其中n為要排序的數的個數,k為要排序的數的組大值。計數排序對一定量的整數排序時候的速度非常快,一般快於其他排序演算法。但計數排序局限性比較大,只限於對整數進行排序。計數排序是消耗空間發雜度來擷取快捷的排序方法,其空間發展度為O(K)同理K為要排序的最大值。

計數排序的基本思想為一組數在排序之前先統計這組數中其他數小於這個數的個數,則可以確定這個數的位置。例如要排序的數為 7 4 2 1 5 3 1 5;則比7小的有7個數,所有7應該在排序好的數列的第八位,同理3在第四位,對於重複的數字,1在1位和2位(暫且認為第一個1比第二個1小),5和1一樣位於6位和7位。

範例程式碼:

#! /usr/bin/env python#coding=utf-8#計數排序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]#!!!!!減一是關鍵    c[a[j]] = c[a[j]] - 1  print bif __name__ == '__main__':  a=[2, 5, 3, 0, 2, 3, 0, 3]  #b=[0]*len(a)  b=[None for i in range(len(a))]  print "幫客之家測試結果:"  CountingSort(a, b, max(a))

運行結果:

PS:關於排序演算法的詳細說明還可參考本站線上工具:

線上動畫示範插入/選擇/冒泡/歸併/希爾/快速排序演算法過程工具
http://tools.jb51.net/aideddesign/paixu_ys

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.