青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

熱轉(zhuǎn)印www.yxheatpress.com

公司網(wǎng)站模板http://qiyemoban.software8.co/

常用鏈接

統(tǒng)計(jì)

友情鏈接

最新評(píng)論

數(shù)據(jù)結(jié)構(gòu):堆

堆常用來實(shí)現(xiàn)優(yōu)先隊(duì)列,在這種隊(duì)列中,待刪除的元素為優(yōu)先級(jí)最高(最低)的那個(gè)。在任何時(shí)候,任意優(yōu)先元素都是可以插入到隊(duì)列中去的,是計(jì)算機(jī)科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱

一、堆的定義

最大(最?。┒咽且豢妹恳粋€(gè)節(jié)點(diǎn)的鍵值都不小于(大于)其孩子(如果存在)的鍵值的樹。大頂堆是一棵完全二叉樹,同時(shí)也是一棵最大樹。小頂堆是一棵完全完全二叉樹,同時(shí)也是一棵最小樹。

注意:

  • 堆中任一子樹亦是堆。
  • 以上討論的堆實(shí)際上是二叉堆(Binary Heap),類似地可定義k叉堆。

下圖分別給出幾個(gè)最大堆和最小堆的例子:


二、支持的基本操作

堆支持以下的基本操作:
  • build: 建立一個(gè)空堆;
  • insert: 向堆中插入一個(gè)新元素;
  • update:將新元素提升使其符合堆的性質(zhì);
  • get:獲取當(dāng)前堆頂元素的值;
  • delete:刪除堆頂元素;
  • heapify:使刪除堆頂元素的堆再次成為堆。

某些堆實(shí)現(xiàn)還支持其他的一些操作,如斐波那契堆支持檢查一個(gè)堆中是否存在某個(gè)元素。

三、堆的應(yīng)用

1.堆排序

 堆排序(HeapSort)是一樹形選擇排序。
     堆排序的特點(diǎn)是:在排序過程中,將R[l..n]看成是一棵完全二叉樹的順序存儲(chǔ)結(jié)構(gòu),利用完全二叉樹中雙親結(jié)點(diǎn)和孩子結(jié)點(diǎn)之間的內(nèi)在關(guān)系【參見二叉樹的順序存儲(chǔ)結(jié)構(gòu)】,在當(dāng)前無序區(qū)中選擇關(guān)鍵字最大(或最小)的記錄。
優(yōu)點(diǎn)直接選擇排序中,為了從R[1..n]中選出關(guān)鍵字最小的記錄,必須進(jìn)行n-1次比較,然后在R[2..n]中選出關(guān)鍵字最小的記錄,又需要做n-2次比較。事實(shí)上,后面的n-2次比較中,有許多比較可能在前面的n-1次比較中已經(jīng)做過,但由于前一趟排序時(shí)未保留這些比較結(jié)果,所以后一趟排序時(shí)又重復(fù)執(zhí)行了這些比較操作。
     堆排序可通過樹形結(jié)構(gòu)保存部分比較結(jié)果,可減少比較次數(shù)。
堆排序利用了大根堆(或小根堆)堆頂記錄的關(guān)鍵字最大(或最小)這一特征,使得在當(dāng)前無序區(qū)中選取最大(或最小)關(guān)鍵字的記錄變得簡單。
(1)、用大根堆排序的基本思想
  • 先將初始文件R[1..n]建成一個(gè)大根堆,此堆為初始的無序區(qū)
  • 再將關(guān)鍵字最大的記錄R[1](即堆頂)和無序區(qū)的最后一個(gè)記錄R[n]交換,由此得到新的無序區(qū)R[1..n-1]和有序區(qū)R[n],且滿足R[1..n-1].keys≤R[n].key
  • 由于交換后新的根R[1]可能違反堆性質(zhì),故應(yīng)將當(dāng)前無序區(qū)R[1..n-1]調(diào)整為堆。然后再次將R[1..n-1]中關(guān)鍵字最大的記錄R[1]和該區(qū)間的最后一個(gè)記錄R[n-1]交換,由此得到新的無序區(qū)R[1..n-2]和有序區(qū)R[n-1..n],且仍滿足關(guān)系R[1..n-2].keys≤R[n-1..n].keys,同樣要將R[1..n-2]調(diào)整為堆。直到無序區(qū)只有一個(gè)元素為止。
(2)、大根堆排序算法的基本操作:
  • 初始化操作:將R[1..n]構(gòu)造為初始堆;
  • 每一趟排序的基本操作:將當(dāng)前無序區(qū)的堆頂記錄R[1]和該區(qū)間的最后一個(gè)記錄交換,然后將新的無序區(qū)調(diào)整為堆(亦稱重建堆)。
  注意:
  • 只需做n-1趟排序,選出較大的n-1個(gè)關(guān)鍵字即可以使得文件遞增有序。
  • 用小根堆排序與利用大根堆類似,只不過其排序結(jié)果是遞減有序的。堆排序和直接選擇排序相反:在任何時(shí)刻,堆排序中無序區(qū)總是在有序區(qū)之前,且有序區(qū)是在原向量的尾部由后往前逐步擴(kuò)大至整個(gè)向量為止。
(3)、算法實(shí)現(xiàn)
  1. ////////////////////////////////////////////////////////////////////   
  2. //堆排序  
  3. template <class T>  
  4. void Sort::HeapSort(T arr[], int len){  
  5.     int i;   
  6.       
  7.     //建立子堆   
  8.     for(i = len / 2; i >= 1; i--){  
  9.         CreateHeap(arr, i, len);  
  10.     }  
  11.       
  12.     for(i = len - 1; i >= 1; i--){  
  13.         buff = arr[1];  
  14.         arr[1] = arr[i + 1];  
  15.         arr[i + 1] = buff;   
  16.           
  17.         CreateHeap(arr, 1, i);   
  18.     }  
  19. }   
  20.   
  21.   
  22. //建立堆   
  23. template <class T>  
  24. void Sort::CreateHeap(T arr[], int root, int len){  
  25.     int j = 2 * root;                   //root's left child, right (2 * root + 1)   
  26.     T temp = arr[root];  
  27.     bool flags = false;   
  28.       
  29.     while(j <= len && !flags){  
  30.         if(j < len){  
  31.             if(arr[j] < arr[j + 1]){     // Left child is less then right child   
  32.                 ++j;                // Move the index to the right child   
  33.             }     
  34.         }  
  35.           
  36.         if(temp < arr[j]){  
  37.             arr[j / 2] = arr[j];  
  38.             j *= 2;   
  39.         }else{  
  40.             flags = true;   
  41.         }   
  42.     }   
  43.    arr[j / 2]  = temp;   
  44. }   

2.選擇前k個(gè)最大(最?。┑臄?shù)

思想:在一個(gè)很大的無序數(shù)組里面選擇前k個(gè)最大(最小)的數(shù)據(jù),最直觀的做法是把數(shù)組里面的數(shù)據(jù)全部排好序,然后輸出前面最大(最小)的k個(gè)數(shù)據(jù)。但是,排序最好需要O(nlogn)的時(shí)間,而且我們不需要前k個(gè)最大(最小)的元素是有序的。這個(gè)時(shí)候我們可以建立k個(gè)元素的最小堆(得出前k個(gè)最大值)或者最大堆(得到前k個(gè)最小值),我們只需要遍歷一遍數(shù)組,在把元素插入到堆中去只需要logk的時(shí)間,這個(gè)速度是很樂觀的。利用堆得出前k個(gè)最大(最?。┰靥貏e適合海量數(shù)據(jù)的處理。

代碼:

  1. typedef multiset<int, greater<int> >            intSet;  
  2. typedef multiset<int, greater<int> >::iterator  setIterator;  
  3.   
  4. void GetLeastNumbers(const vector<int>& data, intSet& leastNumbers, int k)  
  5. {  
  6.     leastNumbers.clear();  
  7.   
  8.     if(k < 1 || data.size() < k)  
  9.         return;  
  10.   
  11.     vector<int>::const_iterator iter = data.begin();  
  12.     for(; iter != data.end(); ++ iter)  
  13.     {  
  14.         if((leastNumbers.size()) < k)  
  15.             leastNumbers.insert(*iter);  
  16.   
  17.         else  
  18.         {  
  19.             setIterator iterGreatest = leastNumbers.begin();  
  20.   
  21.             if(*iter < *(leastNumbers.begin()))  
  22.             {  
  23.                 leastNumbers.erase(iterGreatest);  
  24.                 leastNumbers.insert(*iter);  
  25.             }  
  26.         }  
  27.     }  
  28. }  
    轉(zhuǎn)載請(qǐng)注明:http://www.software8.co/wzjs/cpp/

posted on 2012-10-16 14:20 不聽話的 閱讀(1087) 評(píng)論(0)  編輯 收藏 引用


只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久综合网站| 亚洲欧美日韩视频一区| 欧美高潮视频| 麻豆成人综合网| 免费欧美在线视频| 欧美高清不卡在线| 欧美日韩三级在线| 国产精品国产三级国产专区53 | 猫咪成人在线观看| 麻豆乱码国产一区二区三区| 欧美电影免费观看高清完整版| 免费亚洲电影| 亚洲美女淫视频| 亚洲一区在线播放| 久久精品国产v日韩v亚洲| 美国十次了思思久久精品导航| 欧美风情在线观看| 国产精品视频999| 一色屋精品视频免费看| 亚洲精品美女| 欧美一区三区三区高中清蜜桃| 久久综合久久综合久久综合| 欧美激情aⅴ一区二区三区| 99精品视频免费全部在线| 香蕉尹人综合在线观看| 美女精品在线观看| 国产精品少妇自拍| 亚洲日本成人| 欧美在线首页| 91久久久久| 日韩亚洲欧美综合| 久久国产精品72免费观看| 欧美区高清在线| 激情一区二区三区| 亚洲综合999| 亚洲乱码国产乱码精品精可以看| 午夜精品在线看| 午夜亚洲性色福利视频| 亚洲国产成人高清精品| 一区二区三区精品视频在线观看 | 韩曰欧美视频免费观看| 一区二区日韩伦理片| 噜噜噜久久亚洲精品国产品小说| 一卡二卡3卡四卡高清精品视频| 久久在线播放| 国产一区二区三区高清播放| 亚洲一区二区在线视频| 欧美国产日韩免费| 欧美在线观看天堂一区二区三区| 国产精品久久久91| 9国产精品视频| 亚洲电影下载| 久久综合狠狠综合久久综青草 | 午夜亚洲性色视频| 国产精品sm| 亚洲色图综合久久| 亚洲激情国产| 欧美日本韩国在线| 亚洲精品国产精品国自产在线| 久久久久国内| 欧美一区二区三区免费看 | 亚洲国产日韩欧美一区二区三区| 午夜精品久久久久久99热| 国产精品久久二区| 亚洲综合色网站| 亚洲免费影院| 国产日韩一区二区三区在线| 欧美一级欧美一级在线播放| 亚洲伊人观看| 国产亚洲欧美日韩一区二区| 久久免费午夜影院| 久久狠狠亚洲综合| 一区免费观看| 欧美国产欧美亚洲国产日韩mv天天看完整 | 欧美一级淫片播放口| 国产精品最新自拍| 欧美在线免费播放| 欧美成人免费观看| 一区二区三区精密机械公司| 欧美福利电影网| 在线亚洲欧美| 中日韩男男gay无套| 国产女人精品视频| 久久久亚洲欧洲日产国码αv| 久久久水蜜桃| 亚洲精品国产精品国自产观看浪潮 | 欧美一区二区视频在线| 午夜影视日本亚洲欧洲精品| 在线观看国产精品淫| 亚洲国产岛国毛片在线| 欧美日韩伦理在线| 久久福利视频导航| 久久亚洲一区二区| 中文一区二区在线观看| 亚洲永久免费观看| 亚洲国产精品黑人久久久| 亚洲伦理网站| 国精品一区二区| 亚洲激情网站| 国产在线精品二区| 亚洲精品久久久蜜桃| 国产亚洲第一区| 亚洲国产精品小视频| 国产精品日日摸夜夜添夜夜av| 欧美va天堂va视频va在线| 欧美少妇一区二区| 欧美激情亚洲激情| 国产酒店精品激情| 亚洲精品影院在线观看| 国产综合在线视频| 亚洲综合电影一区二区三区| 亚洲人成在线免费观看| 久久超碰97人人做人人爱| 亚洲少妇在线| 亚洲人成网站777色婷婷| 国产手机视频精品| 亚洲日本成人网| 亚洲第一精品夜夜躁人人躁| 在线亚洲电影| av成人免费在线| 久久免费午夜影院| 久久久久成人网| 国产精品va在线| 99re成人精品视频| 亚洲欧洲一区二区三区| 午夜一区在线| 久久成人精品一区二区三区| 欧美日韩免费一区| 亚洲人屁股眼子交8| 黑人巨大精品欧美一区二区 | 亚洲亚洲精品在线观看| 日韩天堂在线视频| 欧美gay视频| 裸体一区二区三区| 极品尤物久久久av免费看| 国产一区白浆| 亚洲女女做受ⅹxx高潮| 欧美激情影音先锋| 美女视频黄a大片欧美| 国产一区91| 久久精品首页| 久久夜色精品国产| 国产欧美日韩精品专区| 亚洲视频一区二区| 校园春色综合网| 国产欧美精品一区| 午夜视频在线观看一区| 欧美一级片久久久久久久| 国产精品视频免费| 亚洲永久精品大片| 久久免费少妇高潮久久精品99| 一区二区三区在线视频观看 | 久久久久亚洲综合| 久久视频在线免费观看| 影院欧美亚洲| 欧美91视频| 亚洲最新色图| 香蕉免费一区二区三区在线观看| 国产欧美日韩视频一区二区三区| 午夜在线a亚洲v天堂网2018| 久久亚洲一区二区| 亚洲精品日本| 欧美视频三区在线播放| 亚洲自拍偷拍视频| 欧美xart系列高清| 一区二区三区欧美在线| 国产精品日韩在线播放| 蜜乳av另类精品一区二区| 亚洲国产精品成人精品| 亚洲一区精彩视频| 狠狠色噜噜狠狠狠狠色吗综合| 美日韩精品免费观看视频| 一区二区三区精密机械公司| 久久只精品国产| 夜夜嗨av一区二区三区| 国产婷婷97碰碰久久人人蜜臀| 久久久免费精品视频| 日韩一级大片在线| 久久精品国产91精品亚洲| 亚洲欧洲综合| 国产欧美一区二区精品秋霞影院 | 欧美日韩成人在线| 欧美中文在线观看| 亚洲免费av网站| 久久亚洲视频| 午夜精品久久久久久久99热浪潮 | 亚洲国产高清高潮精品美女| 欧美色另类天堂2015| 久久久夜夜夜| 午夜精品美女自拍福到在线 | 亚洲麻豆视频| 国产一区二区三区丝袜| 国产精品二区在线| 欧美xxx在线观看| 久久久99久久精品女同性| 99国产精品久久久| 亚洲激精日韩激精欧美精品| 国产喷白浆一区二区三区| 亚洲网站在线播放| 亚洲人成77777在线观看网|