亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python實(shí)現(xiàn)的計(jì)數(shù)排序算法示例

 更新時(shí)間:2017年11月29日 12:12:55   作者:愛橙子的OK繃  
這篇文章主要介紹了Python實(shí)現(xiàn)的計(jì)數(shù)排序算法,簡單描述了計(jì)數(shù)排序的算法原理并結(jié)合具體實(shí)例形式分析了Python計(jì)數(shù)排序的相關(guān)實(shí)現(xiàn)與使用技巧,需要的朋友可以參考下

本文實(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ì)代碼

    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的問題

    這篇文章主要介紹了解決Pymongo insert時(shí)會自動添加_id的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • python使用rstrip函數(shù)刪除字符串末位字符

    python使用rstrip函數(shù)刪除字符串末位字符

    rstrip函數(shù)用于刪除字符串末位指定字符,默認(rèn)為空白符,這篇文章主要介紹了python使用rstrip函數(shù)刪除字符串末位字符的方法,需要的朋友可以參考下
    2023-04-04
  • 使用PySpider進(jìn)行IP代理爬蟲的技巧與實(shí)踐分享

    使用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-03
  • python連接clickhouse的端口問題及解決

    python連接clickhouse的端口問題及解決

    這篇文章主要介紹了python連接clickhouse的端口問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Python數(shù)據(jù)結(jié)構(gòu)之圖的應(yīng)用示例

    Python數(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-05
  • Python正確重載運(yùn)算符的方法示例詳解

    Python正確重載運(yùn)算符的方法示例詳解

    這篇文章主要給大家介紹了關(guān)于Python如何正確重載運(yùn)算符的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • TensorFlow保存TensorBoard圖像操作

    TensorFlow保存TensorBoard圖像操作

    這篇文章主要介紹了TensorFlow保存TensorBoard圖像操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動畫

    python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動畫

    這篇文章主要為大家詳細(xì)介紹了python游戲開發(fā)之視頻轉(zhuǎn)彩色字符動畫,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • Python?urllib?入門使用詳細(xì)教程

    Python?urllib?入門使用詳細(xì)教程

    urllib?庫,它是?Python?內(nèi)置的?HTTP?請求庫,不需要額外安裝即可使用,這篇文章主要介紹了Python?urllib?入門使用,需要的朋友可以參考下
    2022-11-11

最新評論