麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

堆與優先級隊列——學習筆記

2019-11-14 09:09:58
字體:
來源:轉載
供稿:網友

本篇文章主要基于算法algorithm第四版


背景:處理有序元素時,不一定要求所有數據有序,只要求處理當前最大(優先級最高)的元素 優先級隊列:支持 刪除最大元素插入元素 兩種操作的一種數據結構


【1】優先級隊列的基本表現形式

優先級隊列的基本實現可以使用 有序無序數組鏈表

無序數組或鏈表:刪除最大元素時需要將數組遍歷一遍造出最大元素,插入則無需額外操作有序數組或鏈表:刪除元素時只需直接刪除第一個,插入元素需要保持數據的有序(類似于插入排序) 特點:這類實現的插入元素或刪除最大元素在最壞情況下需要線性時間來完成

【2】基于二叉堆的優先隊列實現方法

基于數組或鏈表的操作最壞情況下需線性時間完成,而用堆來實現優先級隊列可以使兩種操作更快執行

(1)基本定義

堆有序:一棵二叉樹的每個節點大于等于它的兩個子節點二叉堆:一組能夠用 堆有序完全二叉樹 排序的元素

因為二叉堆是完全二叉樹,所以只用數組就可以表示,在二叉堆中位置為k的父結點的位置為ceil(k/2),而子結點為2k和2k+1,這樣方便的表示也使其能通過數組索引方便地上下移動元素

(2)二叉堆的相關算法

在插入或刪除堆中元素時,會打破堆的狀態,所有需要對堆進行遍歷來恢復堆的狀態(堆有序 以及 完全二叉樹),這個過程稱為堆的有序化。有序化過程主要分為兩類:

某個結點的優先級上升(或是在堆底加入新元素時),需要由下至上恢復堆的順序,且形象地稱之為上浮某結點優先級下降(如將根節點替換為更小的元素時),需要由上至下恢復堆的順序,稱之為下沉

(3)優先級隊列的實現

通過有序化的兩個過程我們便可實現插入元素以及刪除最大元素的操作 插入元素:將新元素加到數組末尾,增加堆的大小并讓這個新元素 上浮 到合適的位置 刪除最大元素:從數組刪去最大的元素并將最后一個元素放到堆頂,減小堆的大小,并讓該元素 下沉 到合適的位置 這里寫圖片描述

【3】堆排序

優先隊列可以變成一種排序方法,將所有元素插入一個查找最小元素 的優先隊列,然后再重復調用刪除最小元素的操作來將他們按順序刪去。以此方法來實現排序。 在進行堆排序時,首先要將一組無序數據建立起堆,然后再重復刪去最大(或小)元素

(1)堆的構造

上浮法:逐一將元素加入到已建立的堆尾中,再用上浮法調整堆下沉法:從葉子結點視為已經調整好的堆,然后用下沉法將其父結點下沉至合適位置,以此逐層往上,此法只需要掃描數組中一半的元素,因為我們可以跳過大小為1的子堆

(2)下沉排序

這一階段完成排序工作。從堆中刪除最大元素,然后放入堆縮小后數組中空出的位置,將堆尾元素放到堆頂,進行下沉操作。以此方法重復,則一個最大堆可以得到一個升序序列。


本人學識尚淺,有什么不對的歡迎指出,一起交流交流^ ^


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久综合久久精品 | 久久免费视频7 | 色综合久久久久综合99 | 国产精品视频一区二区三区四区国 | 自拍亚洲伦理 | 依人在线视频 | 国产精品成人一区二区三区电影毛片 | av在线免费在线观看 | a级黄色片视频 | 老师你怎么会在这第2季出现 | 黄色网址进入 | 日韩av官网 | 成人短视频在线观看 | 日韩一级免费 | 成人男女啪啪免费观看网站四虎 | 粉嫩粉嫩一区二区三区在线播放 | 182tv成人福利视频免费看 | 九九热在线免费观看视频 | 国产艳妇av视国产精选av一区 | 桥本有菜免费av一区二区三区 | 亚洲成人自拍电影 | 看免费5xxaaa毛片 | 欧美男女爱爱视频 | 1024亚洲天堂 | 91在线视频免费观看 | 免费国产在线视频 | 国产在线精品区 | 免费a级毛片永久免费 | 久久久久久久91 | 美国av免费看 | 禁漫天堂久久久久久久久久 | 精品久久久一二三区播放播放播放视频 | 中文字幕在线成人 | 亚洲第一成人久久网站 | 一级黄色免费观看 | 久久男 | 极品五月天 | 亚洲成人激情av | 羞羞视频免费视频欧美 | 久久久一区二区三区四区 | 天天夜夜草|