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

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

C++堆排序算法的實現方法

2020-05-23 14:22:12
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了C++堆排序算法的實現方法,很經典的算法,需要的朋友可以參考下
 
 

 本文實例講述了C++實現堆排序算法的方法,相信對于大家學習數據結構與算法會起到一定的幫助作用。具體內容如下:

 首先,由于堆排序算法說起來比較長,所以在這里單獨講一下。堆排序是一種樹形選擇排序方法,它的特點是:在排序過程中,將L[n]看成是一棵完全二叉樹的順序存儲結構,利用完全二叉樹中雙親節點和孩子節點之間的內在關系,在當前無序區中選擇關鍵字最大(或最?。┑脑亍?/p>

一、堆的定義

堆的定義如下:n個關鍵字序列L[n]成為堆,當且僅當該序列滿足:
①L(i) <= L(2i)且L(i) <= L(2i+1)  或者  ②L(i) >= L(2i)且L(i) >= L(2i+1)   其中i屬于[1, n/2]。

滿足第①種情況的堆稱為小根堆(小頂堆),滿足第②種情況的堆稱為大根堆(大頂堆)。在大根堆中,最大元素存放在根結點中,且對任一非根結點,它的值小于或等于其雙親結點值。小根堆則恰恰相反,小根堆的根結點存放的是最小元素。例如{16, 14, 10, 8, 7, 9, 3, 2}表示的大根堆:

                      

二、構造初始堆

堆排序的關鍵就是構造初始堆。n個結點的完全二叉樹中,最后一個結點是第n/2(向下取整)個結點的孩子。所以構造初始堆的流程是:對第n/2(向下取整)個結點為根的子樹進行篩選(以大根堆為例,若根結點的關鍵字小于左右子女中關鍵字的較大者,則交換),使該子樹成為堆。之后向前依次對從n/2-1到1的各結點為根的子樹進行篩選,看該結點值是否大于其左右子結點的值,若不是,將左右子結點中較大值與之交換,交換后可能會破壞下一級的堆,于是繼續采用上述方法構造下一級的堆,直到以該結點為根的子樹構成堆為止。反復利用上述調整堆的方法建堆,直到根結點。

由于在數組中下標從0開始,所以在堆中i的左子結點為2*i+1,右子結點為2*i+2。下面是將某個結點i向下調整建堆的算法實現:

void AdjustDown(ElementType A[], int i, int len) {   ElementType temp = A[i]; // 暫存A[i]      for(int largest=2*i+1; largest<len; largest=2*largest+1)   {     if(largest!=len-1 && A[largest+1]>A[largest])       ++largest;     // 如果右子結點大     if(temp < A[largest])     {       A[i] = A[largest];       i = largest;     // 記錄交換后的位置     }     else       break;   }   A[i] = temp;  // 被篩選結點的值放入最終位置 } 

建堆,從n/2(向下取整)到1依次對各結點向下調整,當然由于數組下標從0開始,所以:

void BuildMaxHeap(ElementType A[], int len) {   for(int i=len/2-1; i>=0; --i) // 從i=n/2-1到0,反復調整堆     AdjustDown(A, i, len); } 

三、堆排序

構造初始堆成功以后,堆排序的思路就很簡單了:首先將存放在L[n]中的n個元素建成初始堆,由于堆本身的特點(以大根堆為例),堆頂元素就是最大值。輸出堆頂元素后,通常將堆底元素送入堆頂,此時根結點已不滿足大根堆的性質,堆被破壞。這時將堆頂元素向下調整使其繼續保持大根堆的性質,再輸出堆頂元素。如此重復,直到堆中僅剩下一個元素為止。算法實現如下:

void HeapSort(ElementType A[], int n) {   BuildMaxHeap(A, n);    // 初始建堆   for(int i=n-1; i>0; --i) // n-1趟的交換和建堆過程    {     // 輸出最大的堆頂元素(和堆底元素交換)     A[0] = A[0]^A[i];     A[i] = A[0]^A[i];     A[0] = A[0]^A[i];     // 調整,把剩余的n-1個元素整理成堆     AdjustDown(A, 0, i);     } } 

四、性能分析

時間復雜度:向下調整的時間與樹高有關,為O(h)??梢宰C明在元素個數為n的序列上建堆,其時間復雜度為O(n)。之后還有n-1次向下調整操作,每次調整的時間為O(h),故在最好,最壞和平均情況下,堆排序的時間復雜度為O(nlogn)。

空間復雜度:僅使用了常數個輔助單元,空間復雜度為O(1)。

穩定性:不穩定。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩亚洲激情| 精品美女国产在线| 成人av色在线观看| 国产男女猛烈无遮挡91| 98视频在线噜噜噜国产| 久久午夜a级毛片| 久久免费福利视频| 日韩欧美在线字幕| 日韩在线观看高清| 日韩亚洲精品电影| 九九久久久久99精品| 在线日韩欧美视频| 亚洲精品狠狠操| 97在线看免费观看视频在线观看| 九九精品在线视频| 久久久精品免费视频| 亚洲精品一区中文字幕乱码| 国产精品久久久久久久av电影| 亚洲一区制服诱惑| 国产福利精品av综合导导航| 最近中文字幕2019免费| 久久人人爽人人爽人人片亚洲| 最新中文字幕亚洲| 亚洲аv电影天堂网| 欧美激情日韩图片| 久久精品国产91精品亚洲| 亚洲欧美日韩视频一区| 日韩中文字幕不卡视频| 午夜精品www| 欧美精品激情blacked18| 日韩高清电影免费观看完整版| 亚洲人成在线播放| 久久亚洲精品网站| 美女性感视频久久久| 欧美一级免费视频| 久久精视频免费在线久久完整在线看| 欧美日韩国产在线看| 色婷婷综合成人av| 中文字幕视频在线免费欧美日韩综合在线看| 精品欧美国产一区二区三区| 欧美xxxx做受欧美.88| 国产自产女人91一区在线观看| 亚洲一区二区三区视频| 午夜精品视频在线| 国产v综合ⅴ日韩v欧美大片| 4438全国亚洲精品在线观看视频| 亚洲丝袜一区在线| 久久免费视频在线| 中文字幕精品—区二区| 一本色道久久综合狠狠躁篇的优点| 性色av香蕉一区二区| 7777精品视频| 国产欧美日韩免费看aⅴ视频| 北条麻妃在线一区二区| 91精品国产色综合久久不卡98口| 狠狠色狠色综合曰曰| 欧美亚洲免费电影| 亚洲国产精品久久精品怡红院| 亚洲精品福利在线观看| 久久91亚洲精品中文字幕奶水| 热re91久久精品国99热蜜臀| 亚洲第一级黄色片| 国产精品偷伦一区二区| 欧美成人精品激情在线观看| 久久免费视频观看| 久久久噜噜噜久噜久久| 久久久999国产| 最近2019免费中文字幕视频三| 欧美大片在线看免费观看| 亚洲欧洲第一视频| 亚洲精品欧美日韩| 成人免费网站在线观看| 欧美综合国产精品久久丁香| 97在线看免费观看视频在线观看| 亚洲第一偷拍网| 欧美日韩xxxxx| 国产视频综合在线| www.亚洲免费视频| 亚洲国产精品久久久久久| 亚洲日本中文字幕免费在线不卡| 久久久999成人| 2025国产精品视频| 亚洲网在线观看| 欧美一区二区视频97| 亚洲另类xxxx| 欧美在线中文字幕| 中文字幕精品在线| 国产一区二区在线免费视频| 欧美亚洲日本网站| 久久久欧美一区二区| 亚洲a一级视频| 国产精品亚洲综合天堂夜夜| 亚洲精品www| 国产不卡av在线| 欧美成人在线免费视频| 亚洲性xxxx| 国产精品 欧美在线| 亚洲一区亚洲二区| 91精品91久久久久久| 国产精品高潮呻吟久久av黑人| 日韩高清电影免费观看完整版| 午夜免费日韩视频| 日本精品视频在线播放| 欧美大片大片在线播放| 日韩精品极品在线观看播放免费视频| 性欧美长视频免费观看不卡| 亚洲天堂av网| 91精品国产高清久久久久久91| 成人福利视频在线观看| 日韩欧美国产一区二区| 成人性生交大片免费观看嘿嘿视频| 久久亚洲国产成人| 久久人体大胆视频| 亚洲国内高清视频| 国产这里只有精品| 久久99精品久久久久久琪琪| 日韩经典中文字幕| 日本最新高清不卡中文字幕| 日韩电影中文字幕在线| 国产精品久久77777| 欧美成人免费观看| 日韩**中文字幕毛片| 亚洲天堂男人天堂| 成人疯狂猛交xxx| 精品女厕一区二区三区| 91精品久久久久久久久久| 北条麻妃久久精品| 欧美一级淫片videoshd| 91精品国产综合久久香蕉的用户体验| 国模精品系列视频| 国产一区二区日韩精品欧美精品| 日韩欧美亚洲综合| 精品国产91久久久久久| 日韩成人免费视频| 国产日韩在线一区| 亚洲国产欧美一区二区丝袜黑人| 国产精品久久一| 韩日精品中文字幕| 欧美日韩视频在线| 中文字幕欧美视频在线| 欧美成aaa人片在线观看蜜臀| 国产精品美乳在线观看| 久久久成人的性感天堂| 久久综合电影一区| www.日本久久久久com.| 欧美日韩人人澡狠狠躁视频| 日韩美女在线观看一区| 久久久av免费| 91产国在线观看动作片喷水| 亚洲欧美国产精品| 久久精品99久久久香蕉| 欧美日韩中文字幕| 国产成人精品a视频一区www| 国产精品一二三在线| 久久精品国产成人| 亚洲人成在线观| 欧美怡春院一区二区三区| 亚洲综合一区二区不卡| 91久久久久久久一区二区| 国内久久久精品| 欧美韩国理论所午夜片917电影| 亚洲精品资源美女情侣酒店| 欧美日韩亚洲视频| 亚洲一区美女视频在线观看免费|