亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

解讀堆排序算法及用C++實現基于最大堆的堆排序示例

2020-05-23 14:03:04
字體:
來源:轉載
供稿:網友
把待排序的數組構造出最大堆是進行堆排序操作的基本方法,這里將帶大家來解讀堆排序算法及用C++實現基于最大堆的堆排序示例,首先從堆排序的概念開始:
 

1、堆排序定義
n個關鍵字序列Kl,K2,…,Kn稱為堆,當且僅當該序列滿足如下性質(簡稱為堆性質):
(1) ki≤K2i且ki≤K2i+1 或(2)Ki≥K2i且ki≥K2i+1(1≤i≤   )
若將此序列所存儲的向量R[1..n]看做是一棵完全二叉樹的存儲結構,則堆實質上是滿足如下性質的完全二叉樹:樹中任一非葉結點的關鍵字均不大于(或不小于)其左右孩子(若存在)結點的關鍵字。
【例】關鍵字序列(10,15,56,25,30,70)和(70,56,30,25,15,10)分別滿足堆性質(1)和(2),故它們均是堆,其對應的完全二叉樹分別如最小堆示例和最大堆示例所示。
堆排序算法

堆排序算法,C++

 

2、最大堆和最小堆
(1)根結點(亦稱為堆頂)的關鍵字是堆里所有結點關鍵字中最小者的堆稱為最小堆。
(2)結點(亦稱為堆頂)的關鍵字是堆里所有結點關鍵字中最大者,稱為最大堆。
注意:
(1)堆中任一子樹亦是堆。
(2)以上討論的堆實際上是二叉堆(Binary Heap),類似地可定義k叉堆。

3、堆排序的基本思路如下:
(1)把待排序數組構造成一個最大堆
(2)取出樹的根(最大(小)值, 實際算法的實現并不是真正的取出)
(3)將樹中剩下的元素再構造成一個最大堆(這里的構造和第1步不一樣,具體看實現部分)
(4)重復2,3操作,直到取完所有的元素
(5)把元素按取出的順序排列,即得到一個有序數組(在代碼實現里是通過交換操作"無形中"完成的)
在開始實現算法先看幾個結論(證明略):
(1)完全二叉樹A[0:n-1]中的任意節點,其下標為 ii, 那么其子節點的下標分別是為2i+12i+1 和 2(i+1)2(i+1)
(2)大小為n的完全二叉樹A[0:n-1],葉子節點中下標最小的是⌊n2⌋⌊n2⌋, 非葉子節點中下標最大的是⌊n2⌋−1⌊n2⌋−1
(3)如果數組是一個最大堆,那么最大元素就是A[0]
(4)最大堆中任意節點的左右子樹也是最大堆
 
4、實現示例
這里的算法實現使用的是最大堆,首先來解決由數組建立最大堆的問題:

// 用于計算下標為i的節點的兩個子節點的下標值#define LEFT(i) (2 * (i) + 1)#define RIGHT(i) (2 * ((i) + 1))         /* 此函數把一顆二叉樹中以node為根的子樹變成最大堆。 * 注意: 使用的前提條件是 node節點的左右子樹(如果存在的話)都是最大堆。 * 這個函數是整個算法的關鍵。 */void max_heapify(int heap[], int heap_size, int node){  // 這里先不考慮整數溢出的問題  // 先把注意力放在主要的功能上  // 如果數據規模夠大,int類型必然會溢出  int l_child = LEFT(node);  int r_child = RIGHT(node);  int max_value = node;   if (l_child < heap_size && heap[l_child] > heap[max_value])  {    max_value = l_child;  }  if (r_child < heap_size && heap[r_child] > heap[max_value])  {    max_value = r_child;  }  if (max_value != node)  {    swap_val(heap + node, heap + max_value);     // 之后還要保證被交換的子節點構成的子樹仍然是最大堆    // 如果不是這個節點會繼續"下沉",直到合適的位置    max_heapify(heap, heap_size, max_value);  }} /* 將一個數組構造成最大堆 * 自底向上的利用max_heapify函數處理 */void build_max_heap(int heap[], int heap_size){  if (heap_size < 2)  {    return;  }  int first_leaf = heap_size >> 1;//第一個葉子節點的下標   int i;  // 從最后一個非葉子節點開始自底向上構建,  // 葉子節點都看作最大堆,因此可以使用max_heapify函數  for (i = first_leaf - 1; i >= 0; i--)  {    max_heapify(heap, heap_size, i);  }}

函數max_heapify將指定子樹的根節點"下沉"到合適的位置, 最終子樹變成最大堆, 該過程最壞時間復雜度為O(logn)O(log?n)。函數build_max_heap自底向上的調用max_heapify, 最終整個數組滿足最大堆,迭代過程的復雜度為O(nlogn)O(nlog?n), 因此整個函數的最壞時間復雜度也是O(nlogn)O(nlog?n)。 而如果當前數組已經是最大堆了,例如數組原本是降序排列的, 那么max_heapify過程的時間復雜度就是O(1)O(1), 此時build_max_heap的時間復雜度是O(n)O(n),這是最好的情況。

接著實現堆排序過程:

/* heap sort 主函數 */void heap_sort(int heap[], int heap_size){  if (heap == NULL || heap_size < 2)  {    return;  }  //構建最大堆  build_max_heap(heap, heap_size);   int i;  for (i = heap_size - 1; i > 0; i--)  {    /* 把當前樹的根節點交換到末尾     * 相當于取出最大值,樹的規模變小。     * 交換后的樹不是最大堆,但是根的兩顆子樹依然是最大堆     * 滿足調用max_heapify的條件。之所以這樣交換,     * 是因為用max_heapify處理時間復雜度較低,     * 如果不交換而直接"取出"heap[0], 此處可能要使用     * build_max_heap重新建立最大堆,時間復雜度較大     */    swap_val(heap, heap + i);     heap_size--;    //維護最大堆    max_heapify(heap, heap_size, 0);  }}

最終的堆排序算法中,build_max_heap的復雜度是已知的, 迭代部分和build_max_heap的實現類似,而且不難看出, 交換后的根元素在下一次建堆過程中必然下沉到堆底,因此無論情況好壞, 該迭代過程時間復雜度都是O(nlogn)O(nlog?n), 所以整個算法的最好最壞和平均時間復雜度都是O(nlogn)O(nlog?n)。
堆排序算法的空間復雜度是O(1)O(1),從實現上很容易看出來。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品亚洲视频在线观看| 欧美激情一区二区三区久久久| 在线观看国产精品日韩av| 欧美激情在线观看| 8090成年在线看片午夜| 久久精品国产视频| 国产成人在线亚洲欧美| 亚洲a区在线视频| 欧美精品18videos性欧| 国产精品69精品一区二区三区| 欧美成年人在线观看| 欧美日韩黄色大片| 亚洲欧美日韩中文在线| 91免费的视频在线播放| 这里只有精品在线播放| 91欧美精品午夜性色福利在线| 91天堂在线观看| 久久不射热爱视频精品| 欧美日韩一区二区在线播放| 日韩av在线免费播放| 最新亚洲国产精品| 欧美日韩第一页| 日韩精品在线免费观看视频| 日韩综合视频在线观看| 久久久免费电影| 精品亚洲一区二区三区在线播放| 亚洲白拍色综合图区| 成人日韩av在线| 久久艹在线视频| 精品视频www| 成人欧美一区二区三区黑人| 日韩av大片在线| 岛国av在线不卡| 欧美黄色片在线观看| 九九九久久国产免费| 欧美日韩精品在线播放| 国产亚洲精品美女久久久久| 欧日韩不卡在线视频| 69av在线视频| 久久国内精品一国内精品| 久久97久久97精品免视看| 亚洲free嫩bbb| 国产精品久久久久久久久久三级| 久久久久久69| 国产精品久久久久久久美男| 久久艳片www.17c.com| 8090成年在线看片午夜| 亚洲美女激情视频| 欧洲午夜精品久久久| 欧美国产在线视频| 欧美成人在线免费视频| 欧美日韩成人在线观看| 欧美激情亚洲一区| 日韩视频免费在线| 亚洲第一av网| 久久精品国产亚洲一区二区| 欧美激情亚洲视频| 欧美大学生性色视频| 日韩精品免费观看| 亚洲国产精品字幕| 欧美激情精品久久久久久大尺度| 欧美亚洲国产精品| 欧美美最猛性xxxxxx| 性欧美办公室18xxxxhd| 欧美国产日韩一区| 热门国产精品亚洲第一区在线| 欧美精品videosex牲欧美| 亚洲精品日韩丝袜精品| 欧美激情久久久久久| 亚洲成人激情小说| 亚洲欧美精品一区二区| 精品久久久久久久久久| 亚洲欧美另类国产| www.99久久热国产日韩欧美.com| 伊人久久综合97精品| 久久香蕉频线观| 亚洲电影免费观看高清完整版在线| 精品国产一区二区三区四区在线观看| 久久中文字幕国产| 欧美激情videoshd| 亚洲电影av在线| 欧美一级片久久久久久久| 成人在线激情视频| 久久久91精品| 中文字幕日韩精品在线观看| 中文字幕亚洲无线码在线一区| 91精品国产99久久久久久| 不卡av电影院| 欧美精品久久久久久久久久| 亚洲人成自拍网站| 青青草国产精品一区二区| 国产成人一区二区| 亚洲一区亚洲二区| 久久久国产影院| 久久91精品国产91久久跳| 久久91精品国产| 国产日韩欧美一二三区| 按摩亚洲人久久| 国产精品偷伦免费视频观看的| 亚洲人成自拍网站| 国产香蕉一区二区三区在线视频| 日韩电影中文字幕在线| 日韩久久午夜影院| 精品国产福利在线| 精品国产乱码久久久久久虫虫漫画| 亚洲国产天堂久久综合网| 日韩欧美综合在线视频| 456国产精品| 国产丝袜一区视频在线观看| 精品网站999www| 亚洲国产精品久久91精品| 国产亚洲精品久久久久久| 最新国产精品拍自在线播放| 久久伊人精品一区二区三区| 国产深夜精品福利| xxxx欧美18另类的高清| 亚洲图片在区色| 欧美亚洲在线观看| 亚洲高清不卡av| 黑人巨大精品欧美一区二区一视频| 成人性教育视频在线观看| 亚洲自拍偷拍一区| 中文字幕亚洲一区在线观看| 成人免费观看49www在线观看| 久久综合亚洲社区| 亚洲国产精彩中文乱码av在线播放| 欧美日韩视频免费播放| 美女av一区二区三区| 日韩国产高清污视频在线观看| 国产精品一区二区久久久| 国产精品第三页| 国产精品老女人视频| 欧美日韩国产第一页| 亚洲乱亚洲乱妇无码| 欧美xxxx14xxxxx性爽| 精品国产一区二区三区在线观看| 中文字幕在线亚洲| 久久99国产综合精品女同| 亚洲国产精品99| 国产精品永久在线| 中文字幕亚洲欧美日韩在线不卡| 亚洲一二三在线| 亚洲精品久久在线| 欧美中在线观看| 在线观看国产成人av片| 中文字幕日韩专区| 91精品国产91久久久久久| 黑人巨大精品欧美一区二区免费| 欧美国产日本高清在线| 日韩精品高清在线观看| 国产成人一区二区三区| 日韩欧美精品网址| 精品久久久久久久久久ntr影视| 中文字幕日韩av综合精品| 久久久人成影片一区二区三区观看| 裸体女人亚洲精品一区| 久久久免费精品视频| 亚洲欧美日韩在线一区| 在线视频日本亚洲性| 久久亚洲国产精品成人av秋霞| 色老头一区二区三区| 亚洲视频在线观看网站| 97久久国产精品| 91在线视频免费|