欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python實(shí)現(xiàn)的堆排序算法原理與用法實(shí)例分析

 更新時(shí)間:2017年11月22日 10:43:33   作者:Alex Yu  
這篇文章主要介紹了Python實(shí)現(xiàn)的堆排序算法,簡(jiǎn)單描述了堆排序的原理,并結(jié)合實(shí)例形式分析了Python實(shí)現(xiàn)堆排序的相關(guān)操作技巧,代碼中備有較為詳細(xì)的注釋便于理解,需要的朋友可以參考下

本文實(shí)例講述了Python實(shí)現(xiàn)的堆排序算法。分享給大家供大家參考,具體如下:

堆排序(Heapsort)是指利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計(jì)的一種排序算法。堆是一個(gè)近似完全二叉樹的結(jié)構(gòu),并同時(shí)滿足堆性質(zhì):即子結(jié)點(diǎn)的鍵值或索引總是小于(或者大于)它的父節(jié)點(diǎn)。

具體代碼如下:

#-*- coding: UTF-8 -*-
import numpy as np
def MakeHeap(a):
  for i in xrange(a.size / 2 - 1, -1, -1):#對(duì)非葉子節(jié)點(diǎn)的子節(jié)點(diǎn)進(jìn)行調(diào)節(jié),構(gòu)建堆
    AdjustHeap(a, i, a.size)
def AdjustHeap(a, i, n):
  j = i*2 +1                     #選擇節(jié)點(diǎn)i的左子節(jié)點(diǎn)
  x = a[i]                       #選擇節(jié)點(diǎn)的數(shù)值
  while j < n:                    #循環(huán)對(duì)子節(jié)點(diǎn)及其子樹進(jìn)行調(diào)整
    if j + 1 < n and a[j+1] < a[j]:    #找到節(jié)點(diǎn)i子節(jié)點(diǎn)的最小值
      j += 1
    if a[j] >= x :                  #若兩個(gè)子節(jié)點(diǎn)均不小于該節(jié)點(diǎn),則不同調(diào)整
      break
    a[i], a[j] = a[j], a[i]             #將節(jié)點(diǎn)i的數(shù)值與其子節(jié)點(diǎn)中最小者的數(shù)值進(jìn)行對(duì)調(diào)
    i = j                        #將i賦為改變的子節(jié)點(diǎn)的索引
    j = i*2 + 1                   #將j賦為節(jié)點(diǎn)對(duì)應(yīng)的左子節(jié)點(diǎn)
def HeapSort(a):
  MakeHeap(a)                 #構(gòu)建小頂堆
  for i in xrange(a.size - 1,0, -1):   #對(duì)堆中的元素逆向遍歷
    a[i], a[0] = a[0], a[i]           #將堆頂元素與堆中最后一個(gè)元素進(jìn)行對(duì)調(diào),因?yàn)樾№敹阎卸秧斣赜肋h(yuǎn)最小,因此,輸出即為最小元素
    AdjustHeap(a, 0, i)          #重新調(diào)整使剩下的元素仍為一個(gè)堆
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]                    #因?yàn)槎雅判虬创蟮叫∵M(jìn)行排列,采用a[::-1]對(duì)其按從小到大進(jìn)行輸出
  print "---------------------------------------------------------------"

運(yùn)行結(jié)果:

更多關(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)典教程

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Python2.X/Python3.X中urllib庫(kù)區(qū)別講解

    Python2.X/Python3.X中urllib庫(kù)區(qū)別講解

    本篇文章通過對(duì)比給大家詳細(xì)講解了在Python2和Python3中urllib庫(kù)區(qū)別以及用法講解,有需要的朋友跟著學(xué)習(xí)下吧。
    2017-12-12
  • 用python爬取中國(guó)大學(xué)排名網(wǎng)站排名信息

    用python爬取中國(guó)大學(xué)排名網(wǎng)站排名信息

    大家好,本篇文章主要講的是用python爬取中國(guó)大學(xué)排名網(wǎng)站排名信息,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-01-01
  • python中的netCDF4批量處理NC文件的操作方法

    python中的netCDF4批量處理NC文件的操作方法

    這篇文章主要介紹了python的netCDF4批量處理NC格式文件的操作方法,使用python批量提取所有數(shù)據(jù),查看數(shù)據(jù)屬性,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • keras.utils.to_categorical和one hot格式解析

    keras.utils.to_categorical和one hot格式解析

    這篇文章主要介紹了keras.utils.to_categorical和one hot格式解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Python?time模塊時(shí)間獲取和轉(zhuǎn)換方法

    Python?time模塊時(shí)間獲取和轉(zhuǎn)換方法

    這篇文章主要介紹了Python?time模塊時(shí)間獲取和轉(zhuǎn)換,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • python GUI庫(kù)圖形界面開發(fā)之PyQt5圖片顯示控件QPixmap詳細(xì)使用方法與實(shí)例

    python GUI庫(kù)圖形界面開發(fā)之PyQt5圖片顯示控件QPixmap詳細(xì)使用方法與實(shí)例

    這篇文章主要介紹了python GUI庫(kù)圖形界面開發(fā)之PyQt5圖片顯示控件QPixmap詳細(xì)使用方法與實(shí)例,需要的朋友可以參考下
    2020-02-02
  • 使用Python下載抖音各大V視頻的思路詳解

    使用Python下載抖音各大V視頻的思路詳解

    這篇文章主要介紹了使用Python下載抖音各大V視頻的思路詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • Django實(shí)現(xiàn)上傳圖片功能

    Django實(shí)現(xiàn)上傳圖片功能

    這篇文章為大家詳細(xì)主要介紹了Django實(shí)現(xiàn)上傳圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • Python連接Postgres/Mysql/Mongo數(shù)據(jù)庫(kù)基本操作大全

    Python連接Postgres/Mysql/Mongo數(shù)據(jù)庫(kù)基本操作大全

    在后端應(yīng)用開發(fā)中,經(jīng)常會(huì)用到Postgres/Mysql/Mongo這三種數(shù)據(jù)庫(kù)的基本操作,今天小編就給大家詳細(xì)介紹Python連接Postgres/Mysql/Mongo數(shù)據(jù)庫(kù)基本操作,感興趣的朋友一起看看吧
    2021-06-06
  • pandas計(jì)數(shù) value_counts()的使用

    pandas計(jì)數(shù) value_counts()的使用

    這篇文章主要介紹了pandas計(jì)數(shù) value_counts()的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06

最新評(píng)論