Python實現(xiàn)的堆排序算法原理與用法實例分析
本文實例講述了Python實現(xiàn)的堆排序算法。分享給大家供大家參考,具體如下:
堆排序(Heapsort)是指利用堆這種數(shù)據(jù)結(jié)構所設計的一種排序算法。堆是一個近似完全二叉樹的結(jié)構,并同時滿足堆性質(zhì):即子結(jié)點的鍵值或索引總是小于(或者大于)它的父節(jié)點。
具體代碼如下:
#-*- coding: UTF-8 -*-
import numpy as np
def MakeHeap(a):
for i in xrange(a.size / 2 - 1, -1, -1):#對非葉子節(jié)點的子節(jié)點進行調(diào)節(jié),構建堆
AdjustHeap(a, i, a.size)
def AdjustHeap(a, i, n):
j = i*2 +1 #選擇節(jié)點i的左子節(jié)點
x = a[i] #選擇節(jié)點的數(shù)值
while j < n: #循環(huán)對子節(jié)點及其子樹進行調(diào)整
if j + 1 < n and a[j+1] < a[j]: #找到節(jié)點i子節(jié)點的最小值
j += 1
if a[j] >= x : #若兩個子節(jié)點均不小于該節(jié)點,則不同調(diào)整
break
a[i], a[j] = a[j], a[i] #將節(jié)點i的數(shù)值與其子節(jié)點中最小者的數(shù)值進行對調(diào)
i = j #將i賦為改變的子節(jié)點的索引
j = i*2 + 1 #將j賦為節(jié)點對應的左子節(jié)點
def HeapSort(a):
MakeHeap(a) #構建小頂堆
for i in xrange(a.size - 1,0, -1): #對堆中的元素逆向遍歷
a[i], a[0] = a[0], a[i] #將堆頂元素與堆中最后一個元素進行對調(diào),因為小頂堆中堆頂元素永遠最小,因此,輸出即為最小元素
AdjustHeap(a, 0, i) #重新調(diào)整使剩下的元素仍為一個堆
if __name__ == '__main__':
a = np.random.randint(0, 10, size = 10)
print "Before sorting..."
print "---------------------------------------------------------------"
print a
print "---------------------------------------------------------------"
HeapSort(a)
print "After sorting..."
print "---------------------------------------------------------------"
print a[::-1] #因為堆排序按大到小進行排列,采用a[::-1]對其按從小到大進行輸出
print "---------------------------------------------------------------"
運行結(jié)果:

更多關于Python相關內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程》
希望本文所述對大家Python程序設計有所幫助。
相關文章
Python2.X/Python3.X中urllib庫區(qū)別講解
本篇文章通過對比給大家詳細講解了在Python2和Python3中urllib庫區(qū)別以及用法講解,有需要的朋友跟著學習下吧。2017-12-12
keras.utils.to_categorical和one hot格式解析
這篇文章主要介紹了keras.utils.to_categorical和one hot格式解析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
python GUI庫圖形界面開發(fā)之PyQt5圖片顯示控件QPixmap詳細使用方法與實例
這篇文章主要介紹了python GUI庫圖形界面開發(fā)之PyQt5圖片顯示控件QPixmap詳細使用方法與實例,需要的朋友可以參考下2020-02-02
Python連接Postgres/Mysql/Mongo數(shù)據(jù)庫基本操作大全
在后端應用開發(fā)中,經(jīng)常會用到Postgres/Mysql/Mongo這三種數(shù)據(jù)庫的基本操作,今天小編就給大家詳細介紹Python連接Postgres/Mysql/Mongo數(shù)據(jù)庫基本操作,感興趣的朋友一起看看吧2021-06-06
pandas計數(shù) value_counts()的使用
這篇文章主要介紹了pandas計數(shù) value_counts()的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-06-06

