国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - 堆排序算法(選擇排序改進)

堆排序算法(選擇排序改進)

2021-01-13 15:24C語言教程網 C/C++

這篇文章主要介紹了堆排序算法(選擇排序改進),有需要的朋友可以參考一下

首先要理解堆的含義:要么所有節點都不大于其子孩子節點數據,要么都不小于其子孩子節點數據

堆排序的核心思想:就是要滿足所有節點都滿足上面兩點,如何完成,看下面

堆排序的步驟:

1.首先要建成一個大頂堆或者小頂堆,在建的過程中其實就是調整節點的位置,首先要從最后最后一個節點的母親節點開始,按照堆的含義調整。為什么不是最后一個或者其他?因為要保證完整性和不必要性,所以只需從最后一個的母親節點開始即可(下面的堆默認存在順序結構,從索引0開始的,所以有些二叉樹的特性請查閱二叉樹),直至索引節點為0的節點。調整完成后即成為一個堆,但是這里的數據并沒有排序好,所以下一部調整順序。

2.從最后一個數據開始,與第一個數據進行交換,然后按照堆的含義調整第一個數據。為什么先選擇最后一個數據?因為默認情況下,最后一個或者是較大或者是較小,可以滿足調整要求。這時就考慮當前所有數據減去最后一個,因為這個已是最大或者是最小,不必再考慮.。直至調整沒有任何數據,此時已完成排序。

具體圖例不再標識,有此愛好可以參考其他書籍或者網上的介紹,下面看堆排序代碼:

復制代碼 代碼如下:


int HeapSort(MergeType* L)
{
 int i = 0;
 if (!L->elem)
 {
  return -1;
 }

 

 //創建堆
 for (int i = L->len/2-1; i >= 0; i--)
 {
  HeapAdjust(L, i, L->len-1);
 }

 //堆排序
 for (i = L->len-1; i >= 0; i-- )
 {
  swap(L->elem[i], L->elem[0]);
  HeapAdjust(L, 0, i-1);
 }
 return 0; 
}

 

注意:
1)由于父子節點的關系,for循環第一個數據索引其實是L,len-1,但是其父母節點(i)與 當前節點(p)的關系:p = 2i+1 或者2i+2; 如果存儲數據的節點第一個索引不是0而是1,這里p=2i或者p=2i+1,請參看有關書籍的證明,所以當前父母節點:i =(p-1)/ 2 = (L.len-1-1)/2 = L.len/2-1

2)由于再次調整數據的時候是從最后一個數據,所以需要交換數據swap,再進行當前頂點數據也就是第一個數據的堆調整,但是此時調整的對象只是(0~i)這些數據,其他已經排序好,所以不再需要調整

下面看一下調整代碼,如下:

復制代碼 代碼如下:

int HeapAdjust(MergeType* L, int nPos, int nEnd)
{
 for (int i = nPos*2+1; i < nEnd ; i = 2*i+1)
 {
  if (L->elem[i] <= L->elem[i+1])
  {
   i++;
  }
  if (L->elem[nPos] >= L->elem[i])
  {
   break;
  }
  swap(L->elem[nPos], L->elem[i]);
  nPos = i;
 }
 return 0;
}

 

這里使用的是在一個層次上是數據直接交換,其實這不是必須的,因為最后才把數據放到最后的位置,所以也可以使用下面的代碼,減少復制的次數

復制代碼 代碼如下:


int HeapAdjustEx(MergeType* L, int nPos, int nEnd)
{
 int nTempkey = L->elem[nPos];

 

 for (int i = nPos*2+1; i < nEnd ; i = 2*i+1)
 {
  if (L->elem[i] <= L->elem[i+1])//選出最大的子孩子
  {
   i++;
  }
  if (nTempkey >= L->elem[i]) //如果當前節點大于最大子孩子退出
  {
   break;
  }
  L->elem[nPos] = L->elem[i]; //否則進行數據交換
  nPos = i;
 }
 L->elem[nPos] = nTempkey;
 return 0;
}

 

這里就可以減少較多的復制操作,也就是俗稱的移動操作次數;這里for循環的起始節點按照上面的推論,子節點應該為p=2i+1,所以第一個應該為2*nPos+1,對應當前要比較節點的做孩子,右孩子為2*nPos+2,也就是左孩子+1,其他請看注釋。
時間復雜度:O(nlogn),分析過程暫略

延伸 · 閱讀

精彩推薦
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 不卡一区二区三区视频 | 亚洲毛片在线观看 | 精品久久久久久久 | 人人人人澡人人爽人人澡 | 一区二区精品 | 一区亚洲| 玖玖操| 夜夜操天天操 | 毛片视频免费播放 | 亚洲在线观看免费视频 | 成人一区二区在线 | 欧美日韩久久久久 | 成人片在线播放 | 日韩在线观看中文字幕 | 亚洲精品一区在线观看 | 高清一区二区三区 | 国产精品视频播放 | 久久国产精品99久久久久久老狼 | 日本一区二区在线观看视频 | 特黄特色的大片观看免费视频 | 九九亚洲 | 国产美女网站视频 | 亚洲一区欧美 | 天天综合网91 | 亚洲国产一区二区三区 | 黄色三级网站在线观看 | 欧美一区二区三区在线观看视频 | 国产精品99久久久久久动医院 | 欧美影院 | 日本在线免费 | 久久99精品国产麻豆婷婷洗澡 | 国产亚洲一区二区三区 | 91精选 | 在线观看中文字幕 | 色伊人| 91se在线 | 欧美亚洲第一页 | 97精品一区二区三区 | 美日韩一区 | 久久亚洲美女 | 久久视频一区 |