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

liyuxia713

蹣跚前行者

常用鏈接

統計

Algorithms

C++

最新評論

二叉排序樹

 1//BTreeNode.h 二叉樹結點抽象類型
 2
 3#ifndef BTREENODE_H
 4#define BTREENODE_H
 5
 6#include <cstdlib>
 7//template<class T> class BTree;
 8template<class T> class SortBTree;
 9
10template<class T> class BTreeNode
11{
12    //friend class BTree<T>;
13    friend class SortBTree<T>;
14public:
15    BTreeNode():lchild(NULL),rchild(NULL){    };
16    BTreeNode(const T&dt, BTreeNode<T> *lch =NULL , BTreeNode<T> *rch = NULL)
17        :data(dt),lchild(lch),rchild(rch){};
18
19    T get_data()const {return data;    };    
20    BTreeNode<T>* get_lchild()const {return lchild;    };
21    BTreeNode<T>* get_rchild()const {return rchild;    };
22    void set_data(const T& d) { data = d;};    
23protected:
24private:
25    T data;
26    BTreeNode<T> *lchild, *rchild;
27}
;
28
29#endif
  1/************************************************************************
  2* SortBTree.h
  3* 根據給定的字符串構造一個排序二叉樹
  4* 從排序二叉樹中尋找最大值,最小值,不存在時拋出invalid_argument異常
  5* 從排序二叉樹中刪除某一元素,不存在時拋出invalid_argument 異常
  6* 往排序二叉樹中添加一個新元素                                                                     
  7************************************************************************/

  8
  9#ifndef SORTBTREE_H
 10#define SORTBTREE_H
 11
 12#include "BTreeNode.h"
 13#include <cstdlib>
 14#include <stdexcept>
 15
 16template<class T>
 17class SortBTree
 18{
 19public:
 20    SortBTree(T* p , int n);
 21    
 22    const T& max()const// return the maximum
 23    const T& min()const// return the minimum
 24    
 25    BTreeNode<T>* find_data(const T& data)const//return the node of data, if data is not exist, throw error
 26    void delete_data(const T& data) { delete_data(root,data); }//delete the node of data, if data is not exist, throw error
 27    void insert_data(const T& data) { insert_data(root,data); };
 28
 29    BTreeNode<T>* get_root()const {return root; }// return the root of tree
 30    void display()const    { display(root,visit); cout << endl;};    // print the data of tree
 31    
 32protected:
 33    static void insert_data(BTreeNode<T> * &root, const T& ndata); //這里必須是對指針的引用,切記,切記    
 34    static BTreeNode<T>* find_data(BTreeNode<T>* r,const T& data);
 35    static void delete_node(BTreeNode<T> * &p);
 36    static void delete_data(BTreeNode<T>* &r, const T& data);
 37    static void display(BTreeNode<T>*p, void visit(BTreeNode<T>* p));    
 38private:
 39    BTreeNode<T> *root;    
 40}
;
 41
 42//construction function
 43template<class T>
 44SortBTree<T>::SortBTree(T* p, int n)
 45{
 46    root = new BTreeNode<T>;
 47    root = NULL; //注意這行很必要,BTreeNode沒有默認設置為NULL的構造函數
 48    for(int i = 0; i != n; ++i)
 49    {        
 50        insert_data(root,p[i]);
 51    }

 52}

 53
 54// insert a new data 
 55template<class T>
 56void SortBTree<T>::insert_data(BTreeNode<T> *&rt,const T& ndata)
 57{
 58    if(rt == NULL) 
 59    {
 60        rt = new BTreeNode<T>(ndata,NULL,NULL);
 61        //rt->data = ndata; //這三條語句不等于上面那條
 62        //rt->lchild = NULL; //用這三條語句是錯的
 63        //rt->rchild = NULL;
 64    }

 65    else if(rt->data == ndata) return;
 66    else if(rt->data > ndata) insert_data(rt->lchild, ndata);
 67    else insert_data(rt->rchild, ndata);
 68}

 69
 70// delete a node from tree(improved)
 71// 如果p沒有左子樹,則讓p的右子樹的根代替p即可。
 72// 如果p有左子樹,找出左子樹中結點值最大的節點temp(最右下角的結點,也是中序遍歷最后一個結點,他沒有右子樹)
 73// 用temp的結點值替換下p的結點值
 74// 刪除temp(因為temp的右子樹為空,從而直接用其左子樹根代替本身就可達到刪除結點的目的)
 75// 注: 一般的方法用temp替換p,但是這樣可能導致樹很不平衡。
 76template<class T>
 77void SortBTree<T>::delete_node(BTreeNode<T> * &p)
 78{
 79    if(p == NULL) cout << "There is not this node." <<endl;
 80    else if(p->lchild == NULL) p = p->rchild;
 81    else
 82    {
 83        BTreeNode<T>* temp = p;
 84        //記錄左子樹中序遍歷的最后一個結點(值最大的點)
 85        while(temp->rchild != NULL)
 86            temp = temp->rchild;    
 87        //刪除這個結點,等價于用這個結點的做子樹代替這個結點(因為這個結點沒有右子樹)
 88        BTreeNode<T>* parent;
 89        parent = temp;
 90        while(parent->rchild != NULL)
 91        {
 92            parent = temp;
 93            temp = temp->rchild;
 94        }

 95        parent = temp->lchild;
 96        p->set_data(temp->data);        
 97    }

 98}

 99
100//delete a data
101template<class T>
102void SortBTree<T>::delete_data(BTreeNode<T>* &root, const T& data)
103{
104    if(root == NULL)
105        throw std::invalid_argument("This data is not exsit.");
106    else if(root->data == data) delete_node(root);
107    else if(root->data > data) delete_data(root->lchild,data);
108    else delete_data(root->rchild,data);
109}

110
111// find a specific data
112template<class T>
113BTreeNode<T>*  SortBTree<T>::find_data(BTreeNode<T>* r,const T& data)
114{
115    if(r == NULL) return r;
116    else if(r->data == data) return r; //注意這兩行是不能合并在一起的,不然可能會出現NULL->data呢
117    else if(r->data > data) return find_data(r->lchild,data);
118    else return find_data(r->rchild,data);
119}

120// find a specific data in tree
121template<class T>
122BTreeNode<T>* SortBTree<T>::find_data(const T& data)const
123{
124    if(find_data(root,data) == NULL)
125        throw std::invalid_argument("This data is not exist.");
126    else 
127        return find_data(root,data);
128}

129
130// return the maximum value 
131template<class T>
132const T& SortBTree<T>::max()const
133{
134    if(root == NULL)
135        throw std::invalid_argument("This is an empty Tree.");
136    else
137    {
138        BTreeNode<T> *= root;
139        while(q->rchild != NULL)
140            q = q->rchild;
141        return q->data;
142    }

143}

144
145//return the minimum value
146template<class T>
147const T& SortBTree<T>::min()const
148{
149    if(root == NULL)
150        throw std::invalid_argument("This is an empty Tree.");
151    else
152    {
153        BTreeNode<T> *= root;
154        while(q->lchild != NULL)
155            q = q->lchild;
156        return q->data;
157    }

158}

159
160//print the sort tree
161template <class T>
162void SortBTree<T>::display(BTreeNode<T>*p, void visit(BTreeNode<T>* p))
163{
164    if(p != NULL)
165    {
166        display(p->lchild,visit);
167        visit(p);
168        display(p->rchild,visit);
169    }
    
170}

171#endif

 1//SortBTree_Test.cpp
 2
 3#include "SortBTree.h"
 4#include <iostream>
 5#include "string"
 6
 7using std::cout;
 8using std::endl;
 9using std::invalid_argument;
10//謂詞函數predicate
11void visit(BTreeNode<char> *p) { std::cout << p->get_data() << " ";};
12
13int main()
14{
15    char *str = "19382";
16    SortBTree<char> sbtr(str,5);
17    SortBTree<char> empty_tree(str,0);
18    cout << "The original sort binary tree is: ";
19    sbtr.display();
20    try
21    {
22        sbtr.find_data('5');
23    }

24    catch (invalid_argument& err)
25    {
26        cout << err.what() <<endl;
27    }

28
29    try
30    {
31        cout << "max = " << sbtr.max() <<endl;
32        cout << "min = " << sbtr.min() <<endl;
33        cout << "max of empty tree = " << empty_tree.max() <<endl;
34    }

35    catch(invalid_argument& err)
36    {
37        cout << err.what() <<endl;
38    }

39
40    try
41    {        
42        sbtr.insert_data('6');
43        sbtr.delete_data('8');
44        sbtr.display();
45        sbtr.delete_data('5');
46        sbtr.display();        
47    }

48    catch (invalid_argument& err)
49    {
50        cout << err.what() <<endl;
51    }

52    
53    return 0;
54}

posted on 2009-04-27 20:57 幸運草 閱讀(1765) 評論(0)  編輯 收藏 引用 所屬分類: Data Structure


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            久久精品一区| 亚洲韩国一区二区三区| 亚洲国产视频一区| 国产精品专区第二| 日韩一本二本av| 亚洲激情图片小说视频| 欧美一区二区福利在线| 亚洲欧美综合精品久久成人| 欧美成人乱码一区二区三区| 久久久久一区二区三区| 国产精品中文在线| 亚洲视频在线观看网站| 9色精品在线| 欧美经典一区二区| 最近看过的日韩成人| 亚洲黄色高清| 麻豆成人在线| 欧美激情一区二区三区四区| 在线观看欧美激情| 久久久国际精品| 久久一区免费| 在线观看成人小视频| 久久久精品国产99久久精品芒果| 久久不射中文字幕| 国产日韩一区二区三区在线播放| 亚洲欧美日韩在线播放| 欧美一区二区三区四区夜夜大片| 国产伦一区二区三区色一情| 亚洲欧美日韩另类精品一区二区三区| 亚洲男女自偷自拍图片另类| 欧美亚洲成人免费| 亚洲欧美在线另类| 久久久午夜精品| 樱桃国产成人精品视频| 麻豆精品传媒视频| 亚洲日本视频| 亚洲欧美国产精品va在线观看| 国产精品成人一区| 亚洲欧美另类在线| 久久久久国产精品午夜一区| 伊人色综合久久天天五月婷| 免费亚洲电影在线| 99re66热这里只有精品3直播| 亚洲综合好骚| 狠狠操狠狠色综合网| 久久综合久久综合这里只有精品| 亚洲国产导航| 午夜欧美大片免费观看| 黄色小说综合网站| 欧美成人有码| 亚洲资源av| 欧美成人午夜激情视频| 一本色道久久| 国产欧美日韩综合一区在线播放| 久久久人人人| 日韩亚洲精品电影| 久久米奇亚洲| 国产专区欧美精品| 国产日韩欧美视频在线| 欧美一激情一区二区三区| 欧美二区在线看| 亚洲尤物在线| 亚洲国产精品毛片| 国产精品黄色在线观看| 久久一日本道色综合久久| 99精品视频免费全部在线| 久久久女女女女999久久| 日韩一区二区福利| 国产自产精品| 欧美精品尤物在线| 欧美专区福利在线| 一区二区高清在线观看| 老司机aⅴ在线精品导航| 亚洲手机成人高清视频| 亚洲成人自拍视频| 国产欧美日韩一区二区三区在线 | 在线日韩中文| 欧美午夜不卡| 欧美精品v日韩精品v国产精品| 欧美一区二区成人| 亚洲午夜日本在线观看| 亚洲国产一区在线| 久久免费国产精品1| 亚洲欧美日韩精品久久久久| 日韩午夜在线播放| 在线日韩av片| 国产亚洲欧美色| 国产精品视频免费在线观看| 欧美日韩另类视频| 欧美77777| 麻豆精品国产91久久久久久| 欧美自拍偷拍午夜视频| 亚洲欧美日韩一区在线| av不卡在线看| 日韩视频永久免费| 亚洲三级国产| 91久久中文字幕| 亚洲国产视频一区| 欧美激情视频免费观看| 蜜臀99久久精品久久久久久软件 | 亚洲国产精品www| 美国成人直播| 美女91精品| 裸体歌舞表演一区二区| 久久婷婷综合激情| 久久久五月婷婷| 久久精品水蜜桃av综合天堂| 欧美中在线观看| 久久国产天堂福利天堂| 久久av红桃一区二区小说| 久久www成人_看片免费不卡| 久久aⅴ国产欧美74aaa| 久久精品二区三区| 久久久久看片| 欧美福利视频| 欧美多人爱爱视频网站| 亚洲国产影院| 99国产精品视频免费观看| 一区二区三区欧美在线| 亚洲一卡二卡三卡四卡五卡| 亚洲欧美日韩一区二区| 久久精品99久久香蕉国产色戒| 久久精品二区| 欧美激情综合五月色丁香| 欧美视频不卡中文| 国产日韩欧美综合一区| 伊人婷婷欧美激情| 日韩视频在线你懂得| 亚洲永久免费av| 久久精品免费看| 欧美激情1区2区3区| av成人激情| 午夜亚洲伦理| 欧美阿v一级看视频| 欧美午夜精品久久久久久孕妇 | 欧美α欧美αv大片| 亚洲国产精品视频| 亚洲视频播放| 久久免费高清视频| 欧美午夜寂寞影院| 国产一区视频网站| 亚洲毛片在线| 久久精品毛片| 亚洲三级视频| 欧美在线一二三区| 欧美伦理a级免费电影| 国产日韩欧美高清免费| 在线观看日韩欧美| 亚洲一区免费网站| 免费视频一区| 亚洲欧美不卡| 欧美—级高清免费播放| 国产一区二区三区的电影| 亚洲美洲欧洲综合国产一区| 久久精品国产久精国产爱| 亚洲人成网在线播放| 久久不见久久见免费视频1| 欧美精品久久久久久久免费观看| 国产亚洲精品福利| 在线视频精品| 亚洲国产视频直播| 亚洲第一精品久久忘忧草社区| 日韩一级不卡| 男女av一区三区二区色多| 国产精品视频网站| 亚洲精品欧洲| 久色婷婷小香蕉久久| 中日韩美女免费视频网址在线观看 | 欧美日韩成人在线观看| 国内自拍一区| 欧美一级视频一区二区| 日韩天堂在线观看| 欧美成人激情在线| 亚洲成人在线观看视频| 久久黄金**| 亚洲一区二区三区精品在线观看| 欧美激情精品久久久久久变态| 欧美日韩一区二区在线观看视频| 国产一区二区三区免费在线观看| 最新国产成人av网站网址麻豆| 久久av红桃一区二区小说| 99在线精品观看| 欧美黄色大片网站| 在线日韩av| 欧美 日韩 国产精品免费观看| 先锋a资源在线看亚洲| 国产精品久久久久久久久借妻| 日韩天堂在线观看| 亚洲激情女人| 女女同性精品视频| 亚洲国产一区二区三区a毛片| 女女同性精品视频| 久久精品夜色噜噜亚洲aⅴ| 国内偷自视频区视频综合| 亚洲精品久久久久久久久久久| 欧美一区二区福利在线| 国产一区二区三区av电影| 久久精品亚洲精品国产欧美kt∨| 亚洲欧美日韩在线观看a三区| 国产欧美日韩一区二区三区在线 |