Python實現(xiàn)的基數(shù)排序算法原理與用法實例分析
本文實例講述了Python實現(xiàn)的基數(shù)排序算法。分享給大家供大家參考,具體如下:
基數(shù)排序(radix sort)屬于“分配式排序”(distribution sort),又稱“桶子法”(bucket sort)或bin sort,顧名思義,它是透過鍵值的部份資訊,將要排序的元素分配至某些“桶”中,藉以達到排序的作用,基數(shù)排序法是屬于穩(wěn)定性的排序,其時間復(fù)雜度為O (nlog(r)m),其中r為所采取的基數(shù),而m為堆數(shù),在某些時候,基數(shù)排序法的效率高于其它的穩(wěn)定性排序法。
實現(xiàn)代碼如下:
#-*- coding: UTF-8 -*- import numpy as np def RadixSort(a): i = 0 #初始為個位排序 n = 1 #最小的位數(shù)置為1(包含0) max = np.max(a) #得到帶排序數(shù)組中最大數(shù) while max/(10**n) > 0: #得到最大數(shù)是幾位數(shù) n += 1 while i < n: bucket = {} #用字典構(gòu)建桶 for x in xrange(0,10): bucket.setdefault(x, []) #將每個桶置空 for x in a: #對每一位進行排序 radix =(x / (10**i)) % 10 #得到每位的基數(shù) bucket[radix].append(x) #將對應(yīng)的數(shù)組元素加入到相應(yīng)位基數(shù)的桶中 j = 0 for k in xrange(0, 10): if len(bucket[k]) != 0: #若桶不為空 for y in bucket[k]: #將該桶中每個元素 a[j] = y #放回到數(shù)組中 j += 1 i += 1 if __name__ == '__main__': a = np.random.randint(0, 1000, size = 10) print "Before sorting..." print "---------------------------------------------------------------" print a print "---------------------------------------------------------------" RadixSort(a) print "After sorting..." print "---------------------------------------------------------------" print a print "---------------------------------------------------------------"
運行結(jié)果:
更多關(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è)計有所幫助。
- python八大排序算法速度實例對比
- Python實現(xiàn)希爾排序算法的原理與用法實例分析
- Python實現(xiàn)的堆排序算法原理與用法實例分析
- Python實現(xiàn)的插入排序算法原理與用法實例分析
- Python實現(xiàn)的選擇排序算法原理與用法實例分析
- Python實現(xiàn)桶排序與快速排序算法結(jié)合應(yīng)用示例
- Python實現(xiàn)的歸并排序算法示例
- 八大排序算法的Python實現(xiàn)
- Python實現(xiàn)的幾個常用排序算法實例
- Python實現(xiàn)各種排序算法的代碼示例總結(jié)
- Python八大常見排序算法定義、實現(xiàn)及時間消耗效率分析
相關(guān)文章
用python生成與調(diào)用cntk模型代碼演示方法
今天小編就為大家分享一篇用python生成與調(diào)用cntk模型代碼演示方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08Python打開指定網(wǎng)頁使用requests模塊爬蟲示例詳解
這篇文章主要介紹了Python打開指定網(wǎng)頁使用requests模塊爬蟲的示例,Python?requests是一個常用的HTTP請求庫,可以方便地向網(wǎng)站發(fā)送HTTP請求,并獲取響應(yīng)結(jié)果,requests模塊比urllib模塊更簡潔,感興趣的朋友可以參考下2024-02-02Python 中pandas索引切片讀取數(shù)據(jù)缺失數(shù)據(jù)處理問題
pandas是一個Python軟件包,提供快速,靈活和富于表現(xiàn)力的數(shù)據(jù)結(jié)構(gòu),旨在使使用“關(guān)系”或“標記”數(shù)據(jù)既簡單又直觀。這篇文章主要介紹了pandas索引切片讀取數(shù)據(jù)缺失數(shù)據(jù)處理,需要的朋友可以參考下2019-10-10