• <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>
            隨筆 - 8  文章 - 26  trackbacks - 0
            <2010年3月>
            28123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(5)

            隨筆檔案

            文章分類

            文章檔案

            相冊(cè)

            C++語(yǔ)言

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            高度優(yōu)先左高樹(shù)與堆的性質(zhì)類似,都可有作為優(yōu)先級(jí)隊(duì)列的底層結(jié)構(gòu)。但應(yīng)用高度優(yōu)先左高樹(shù)可以很容易的實(shí)現(xiàn)兩個(gè)優(yōu)先級(jí)隊(duì)列的合并操作。

              1//高度優(yōu)先左高樹(shù)(HBLT)實(shí)現(xiàn)
              2#ifndef HBLT_H
              3#define HBLT_H
              4#include <queue>
              5//定義HBLT節(jié)點(diǎn)結(jié)構(gòu)
              6template<class T>
              7class HBLTNode
              8{
              9
             10public:
             11HBLTNode(T &e,int s)
             12{
             13data=e;
             14sh=s;
             15RightChild=LeftChild=NULL;
             16}

             17
             18public:
             19    T data;
             20    int sh;//高度因子
             21    HBLTNode<T> *RightChild,*LeftChild;
             22}
            ;
             23
             24//定義HBLT樹(shù)結(jié)構(gòu)
             25template<class T>
             26class HBLT
             27{
             28public:
             29    HBLT(){size=0,root=NULL;}
             30    virtual ~HBLT();
             31    HBLT<T>& Insert(T e);//插入新元素
             32    HBLT<T>& DeleteMax(T &e);//刪除并返回最大元素
             33    HBLT<T>& Meld(HBLT<T>& x);
             34    bool IsEmpty(){return root==NULL?true:false;}
             35    void Initialize(T a[],int n);//對(duì)HBLT樹(shù)重新初始化
             36    int Size(){return size;}
             37private:
             38
             39 HBLTNode<T> *root;//根節(jié)點(diǎn)指針
             40 int size;
             41 void Meld(HBLTNode<T>*&x,HBLTNode<T>*y);//將以x,y為根的兩棵HBLT樹(shù)合并
             42 void PostVisit(HBLTNode<T> *root);//對(duì)樹(shù)進(jìn)行后序遍歷刪除節(jié)點(diǎn)
             43
             44}
            ;
             45
             46
             47template<class T>
             48HBLT<T>::~HBLT()
             49{
             50PostVisit(root);
             51}

             52//----------------------------------------------------------
             53template<class T>
             54void HBLT<T>::Meld(HBLTNode<T>*&x,HBLTNode<T>*y)
             55{
             56if(!y)//y為空樹(shù)
             57 return;
             58if(!x)//x為空樹(shù)
             59{
             60x=y;
             61return;
             62}

             63
             64if(x->data<y->data) swap(x,y);//保證x指向大值
             65
             66//遞歸合并x的右子樹(shù)與y
             67Meld(x->RightChild,y);
             68
             69if(!x->LeftChild)//如果X的左子樹(shù)為空則將右子樹(shù)移向左邊
             70{
             71x->LeftChild=x->RightChild;
             72x->RightChild=NULL;
             73}

             74else
             75{
             76if(x->LeftChild->sh<x->RightChild->sh)//左子樹(shù)沒(méi)有右子樹(shù)高
             77{
             78swap(x->LeftChild,x->RightChild);
             79x->sh=x->RightChild->sh+1;
             80}

             81}
            //if
             82
             83}

             84//-------------------------------------------------------------
             85template<class T>
             86HBLT<T>& HBLT<T>::Insert(T e)
             87{
             88HBLTNode<T> *NewNode=new HBLTNode<T>(e,1);
             89Meld(root,NewNode);
             90size++;
             91return *this;
             92}

             93
             94//-------------------------------------------------------------
             95template<class T>
             96HBLT<T>& HBLT<T>::DeleteMax(T &e)
             97{
             98
             99e=root->data;
            100HBLTNode<T> *Left=root->LeftChild;
            101HBLTNode<T> *Right=root->RightChild;
            102root=Left;
            103Meld(root,Right);
            104--size;
            105return *this;
            106}

            107
            108//-------------------------------------------------------------
            109template<class T>
            110HBLT<T>& HBLT<T>::Meld(HBLT<T>& x)
            111{
            112Meld(root,x.root);
            113x.root=NULL;
            114size=size+x.size;
            115return *this;
            116}

            117//-------------------------------------------------------------
            118template<class T>
            119void HBLT<T>::PostVisit(HBLTNode<T> *root)
            120{
            121if(root)
            122{
            123PostVisit(root->LeftChild);
            124PostVisit(root->RightChild);
            125delete root;
            126}

            127}

            128//-------------------------------------------------------------
            129template<class T>
            130void HBLT<T>::Initialize(T a[],int n)
            131{
            132if(root)
            133  PostVisit(root);//刪除以前的節(jié)點(diǎn)
            134size=n;
            135queue<HBLTNode<T>* > Q;
            136for(int i=0;i<n;i++)
            137{
            138HBLTNode<T> *NewNode=new HBLTNode<T>(a[i],1);
            139Q.push(NewNode);
            140}

            141
            142for(i=1;i<=n-1;i++)
            143{
            144HBLTNode<T> *Node1 = Q.front();Q.pop();
            145HBLTNode<T> *Node2 = Q.front();Q.pop();
            146Meld(Node1,Node2);
            147Q.push(Node1);
            148}

            149
            150root = Q.front();
            151}

            152#endif
            posted on 2008-09-18 17:27 楊彬彬 閱讀(1552) 評(píng)論(0)  編輯 收藏 引用

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


            精品久久久久久成人AV| 亚洲精品tv久久久久久久久久| 久久精品国产亚洲AV不卡| 日本加勒比久久精品| 青青草国产成人久久91网| 一级女性全黄久久生活片免费| 亚洲AV日韩精品久久久久久久| 精品永久久福利一区二区| 亚洲国产精品综合久久网络| 久久精品国产精品亚洲毛片| 日本WV一本一道久久香蕉| 国产情侣久久久久aⅴ免费| 国产精品99久久免费观看| 93精91精品国产综合久久香蕉| 伊人久久大香线蕉亚洲五月天| 亚洲精品无码久久毛片| 91精品国产综合久久香蕉| 久久99久国产麻精品66| 国产精品永久久久久久久久久| 亚洲人成无码www久久久| 99久久免费国产精品热| 色天使久久综合网天天| 久久久久免费精品国产| 久久婷婷五月综合成人D啪| 久久亚洲AV成人无码电影| 久久精品国产精品亚洲| 狠狠色婷婷综合天天久久丁香| 欧美激情精品久久久久久| 天天影视色香欲综合久久| 亚洲国产精品久久| 精品久久久久久国产91| 久久久无码人妻精品无码| 亚洲愉拍99热成人精品热久久| 久久精品成人欧美大片| 久久精品国产99久久香蕉| segui久久国产精品| 91久久精品国产成人久久| 久久99精品九九九久久婷婷| 精品久久久久久久久久久久久久久| 久久er国产精品免费观看2| 久久无码一区二区三区少妇|