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

Networking /C++/Linux

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  11 Posts :: 14 Stories :: 1 Comments :: 0 Trackbacks

常用鏈接

留言簿(4)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

堆實際上是一個數組對象,可以被視為一個完全二叉樹,有完全二叉樹的遍歷得到(算法導論第六章)

思想:
最大堆和最小堆:
本文以最大堆作為介紹,主要的函數 max_heapify 和 heap_sort  利用遞歸
max_heapify函數的主要作用是調整對的結構,是其滿足最大堆的性質(其中利用遞歸),
max_heapify(int i,int len)len參數是數組的個數,i參數是“備用根”的下標。

代碼:
  1#include<iostream>
  2#include<stdlib.h>
  3#include<time.h>
  4using namespace std;
  5
  6class heap{
  7public
  8        heap()
  9        {
 10                a=NULL;
 11                size=10;
 12                heap(size);
 13        }

 14        
 15        heap(int size_t):size(size_t)
 16        {
 17                a=new int[size+1];
 18                srand(time(NULL));
 19                
 20                for(int i=1;i<=size;i++)
 21                {
 22                        a[i]=rand()%1000;
 23                }

 24        }

 25        
 26       /* heap(int *b)
 27        {
 28                int len=sizeof(b);
 29                size=len;
 30                a=new int[size+1];
 31                
 32                for(int i=1;i<=size;i++)
 33                {        
 34                        a[i]=b[i-1];
 35                }
 36        }*/

 37        
 38        ~heap()
 39        {
 40                cout<<"Destroy..\n";
 41                delete []a;
 42                a=NULL;
 43        }

 44        
 45        void max_heapify(int i,int len);
 46        void build_heap();
 47        void heap_sort();
 48        
 49        
 50        void print();
 51        
 52        int left(int i){return 2*i;}
 53        int right(int i){return 2*i+1;}
 54        int parent(int i ){return i/2;}        
 55private:
 56        int *a;
 57        int size;
 58}
;
 59
 60void heap::heap_sort()
 61{
 62        int len=size;
 63        int t;
 64        
 65        for(int i=size;i>=2;i--)
 66        {
 67                t=a[1];
 68                a[1]=a[i];
 69                a[i]=t;
 70                
 71                len--;
 72                
 73                max_heapify(1,len);
 74        }

 75}

 76
 77
 78void heap::max_heapify(int i,int len)
 79{
 80        int lt,rt;
 81        int max=0;
 82        
 83        lt=left(i);
 84        rt=right(i);
 85        
 86        if(lt<=len&&a[lt]>a[i]){
 87                max=lt;
 88        }

 89        else{
 90                max=i;
 91        }

 92        
 93        if(rt<=len&&a[rt]>a[max]){
 94                max=rt;
 95        }

 96        
 97        if(max!=i){
 98                int t;
 99                t=a[i];
100                a[i]=a[max];
101                a[max]=t;
102                
103                max_heapify(max,len);
104        }
      
105}

106
107void heap::build_heap()
108{
109        for(int i=size/2;i>=1;i--)
110        {
111                max_heapify(i,size);
112        }

113}

114
115void heap::print()
116{
117        for(int i=1;i<=size;i++)
118        {
119                cout<<a[i]<<"\t";
120        }

121        cout<<endl;
122}

123
124
125int main()
126{
127        heap test(10);
128       // test.print();
129        
130        
131        //cout<<endl;
132        test.build_heap();
133        test.print();  
134        
135        cout<<endl;
136        test.heap_sort();
137        test.print() ;     
138
139}

別人的實現:
http://www.cnblogs.com/dolphin0520/archive/2011/10/06/2199741.html
http://student.zjzk.cn/course_ware/data_structure/web/paixu/paixu8.4.2.2.htm
http://www.cnblogs.com/lovemo1314/archive/2011/09/13/2175032.html

posted on 2011-12-05 14:35 likun 閱讀(769) 評論(0)  編輯 收藏 引用 所屬分類: Algorithms
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久综合一区二区| 久久久久久久综合日本| 一区二区三区日韩精品| 久久伊人一区二区| 欧美国产欧美亚洲国产日韩mv天天看完整 | 日韩午夜视频在线观看| 日韩亚洲国产欧美| 欧美国产日韩视频| 黄色综合网站| 久久中文字幕导航| 久久夜色精品| 欧美日韩久久| 亚洲区国产区| 免费观看国产成人| 一片黄亚洲嫩模| 久久精品二区三区| 一区二区三区久久网| 亚洲一区免费视频| 亚洲国产精品一区制服丝袜| 久久都是精品| av成人动漫| 最新中文字幕一区二区三区| 久久国产手机看片| 欧美a级一区| 久久大逼视频| 中文高清一区| 亚洲国产日韩在线一区模特| 99re66热这里只有精品3直播| 香蕉久久精品日日躁夜夜躁| 亚洲国产婷婷香蕉久久久久久| 亚洲精品一区中文| 亚洲激情亚洲| 欧美伊人久久| 香蕉av777xxx色综合一区| 狂野欧美一区| 久久免费视频在线| 亚洲美女黄网| 亚洲欧洲综合| 久久久久国内| 久久一区视频| 国产精品一区二区欧美| 欧美人与性动交cc0o| 欧美成人a∨高清免费观看| 久久国产免费| 欧美激情1区2区| 欧美在线观看你懂的| 亚洲伦理在线免费看| 中文亚洲欧美| 亚洲激情六月丁香| 亚洲欧美成人一区二区在线电影| 久久综合精品一区| 欧美高清在线视频| 欧美成人国产va精品日本一级| 亚洲视频福利| 日韩午夜免费| 亚洲黄色性网站| 久久影音先锋| 在线日韩视频| 91久久国产自产拍夜夜嗨| 亚洲日本欧美在线| 一本色道久久综合一区| 亚洲欧美国产精品桃花| 久久久国产成人精品| 久久午夜影视| 国产一区导航| 国内伊人久久久久久网站视频| 国产在线一区二区三区四区 | 久久久青草婷婷精品综合日韩| 国产日韩精品久久久| 永久555www成人免费| 亚洲欧洲日产国产网站| 欧美大尺度在线观看| 久久久国产视频91| 在线观看视频一区二区| 欧美电影在线免费观看网站| 久久综合给合久久狠狠狠97色69| 在线播放豆国产99亚洲| 午夜在线精品| 欧美涩涩视频| 久久精品视频亚洲| 国产乱码精品一区二区三区五月婷 | 亚洲卡通欧美制服中文| 亚洲日本乱码在线观看| 欧美精品一区二区三区视频| 亚洲免费观看视频| 一区二区三区四区蜜桃| 国产精一区二区三区| 久久婷婷av| 欧美精品一区二区三区一线天视频 | 欧美日韩日韩| 亚洲欧美一区二区三区极速播放| 久久久xxx| 午夜亚洲精品| 欧美日韩免费高清| 午夜宅男久久久| 玖玖视频精品| 亚洲综合首页| 久久亚洲精选| 欧美精品日韩三级| 亚洲国产视频直播| 9l国产精品久久久久麻豆| 国产精品一区久久久| 蜜臀久久99精品久久久画质超高清 | 国产精品三区www17con| 激情亚洲网站| 亚洲精品影院| 国产综合亚洲精品一区二| 欧美激情精品久久久| 国产精品久久看| 在线午夜精品自拍| 香蕉免费一区二区三区在线观看| 亚洲国产精品久久久久婷婷老年 | av72成人在线| 性色一区二区三区| 一区二区三区精品视频| 亚洲欧美日本国产有色| 亚洲国产视频直播| 久久激情网站| 午夜免费久久久久| 宅男精品视频| 亚洲国产精品成人久久综合一区| 一本色道久久综合精品竹菊 | 久久伊伊香蕉| 国产精品久久久久久久久果冻传媒 | 91久久精品一区二区别| 午夜精品福利一区二区三区av | 欧美www视频| 国语精品一区| 欧美一区二区精品久久911| 欧美视频国产精品| 欧美福利视频一区| 国内精品免费午夜毛片| 亚洲欧美日韩精品久久久久| 亚洲综合日韩| 国产精品国产三级国产aⅴ入口| 亚洲成人在线视频网站| 欧美一级电影久久| 欧美香蕉大胸在线视频观看| 在线播放中文一区| 香蕉av福利精品导航| 亚洲欧美日韩综合国产aⅴ| 欧美日韩亚洲一区二区三区在线观看 | 国产精品最新自拍| 亚洲社区在线观看| 午夜精品视频一区| 国产精品一区二区三区观看 | 亚洲电影免费观看高清完整版在线观看 | 久久综合婷婷| 精品福利电影| 麻豆久久久9性大片| 亚洲精品综合精品自拍| 男人插女人欧美| 亚洲国产专区校园欧美| 国产精品国产三级欧美二区| 99re6这里只有精品| 亚洲免费影院| 国产一区二区三区无遮挡| 久久成人国产| 欧美护士18xxxxhd| 一区二区高清在线| 国产精品中文在线| 久久精品一区中文字幕| 亚洲福利一区| 一区二区三区在线观看视频| 久久这里只有| 日韩午夜视频在线观看| 性亚洲最疯狂xxxx高清| 狠狠色综合网| 欧美日韩免费观看一区三区| 亚洲一区在线观看视频| 亚洲另类自拍| 国产精品黄色在线观看| 欧美在线视频观看| 91久久在线| 久久精品在线播放| 一本一本久久| 国产一区二区三区丝袜| 日韩午夜电影av| 亚洲一区二区三区四区中文 | 国产精品专区h在线观看| 久久riav二区三区| 亚洲伦理久久| 久久躁狠狠躁夜夜爽| 一本久久综合亚洲鲁鲁| 国产一级久久| 欧美揉bbbbb揉bbbbb| 久久久夜夜夜| 国产精品激情偷乱一区二区∴| 日韩亚洲一区在线播放| 亚洲欧美卡通另类91av| 好吊一区二区三区| 欧美日韩中文在线观看| 久久久久综合网| 亚洲一区黄色| 亚洲精品一区久久久久久| 狂野欧美性猛交xxxx巴西| 亚洲一区二区三区中文字幕在线| 久久久一区二区| 亚洲一二三区在线| 欧美一区二区性|