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

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>
            99成人免费视频| 欧美aⅴ一区二区三区视频| 亚洲一区中文字幕在线观看| 欧美日韩成人综合| 亚洲一区二区三区777| 欧美一区二区三区成人| 国产一区深夜福利| 欧美mv日韩mv国产网站| 亚洲免费不卡| 久久精品国产亚洲精品| 亚洲电影第三页| 欧美视频在线观看免费| 香蕉免费一区二区三区在线观看| 麻豆精品在线视频| 亚洲视频1区2区| 韩国三级电影一区二区| 欧美激情国产高清| 亚洲自拍偷拍麻豆| 欧美成人综合一区| 亚洲欧美日韩爽爽影院| 亚洲国产成人av| 国产精品久久久久久久久久久久 | 久久深夜福利| 一本到高清视频免费精品| 久久精品中文字幕一区二区三区| 亚洲国产高清一区| 国产精品你懂的在线欣赏| 久久人人97超碰人人澡爱香蕉| 亚洲精品中文字幕女同| 久久人人爽人人爽| 一区二区三区四区五区精品视频| 国产亚洲va综合人人澡精品| 欧美激情视频在线免费观看 欧美视频免费一 | 欧美电影免费观看高清完整版| 亚洲一区二区三区乱码aⅴ蜜桃女| 免播放器亚洲一区| 性欧美1819sex性高清| 亚洲精品国产精品乱码不99| 国产欧美日韩精品a在线观看| 农夫在线精品视频免费观看| 欧美在线播放视频| 一区二区三区欧美在线| 亚洲国产精品一区二区第一页| 亚洲专区免费| 99国产成+人+综合+亚洲欧美| 国内自拍一区| 国产免费亚洲高清| 欧美图区在线视频| 欧美精品福利| 久久综合伊人77777麻豆| 亚洲欧美日韩国产一区| 宅男噜噜噜66国产日韩在线观看| 欧美激情在线狂野欧美精品| 久久综合伊人| 久久偷窥视频| 久久久青草青青国产亚洲免观| 午夜伦欧美伦电影理论片| 一区二区三区色| 亚洲美女av黄| 亚洲欧洲久久| 亚洲区欧美区| 日韩视频精品在线| 91久久精品国产91久久性色tv| 狠狠色2019综合网| 韩国av一区二区| 国内精品久久久久久久影视麻豆| 国产精品一区一区| 国产美女在线精品免费观看| 国产精品试看| 国产小视频国产精品| 国产欧美大片| 国内精品美女av在线播放| 国产亚洲网站| 激情欧美日韩| 亚洲韩国精品一区| 99v久久综合狠狠综合久久| 999亚洲国产精| 亚洲一区二区三区视频| 亚洲在线日韩| 欧美在线视频a| 久久久最新网址| 欧美成人午夜激情在线| 亚洲国产精品久久精品怡红院| 亚洲国产成人久久综合一区| 亚洲精品日韩精品| 一区二区日韩精品| 亚洲摸下面视频| 久久久精品免费视频| 老司机一区二区三区| 欧美高清视频免费观看| 国产精品mm| 国产亚洲人成a一在线v站| 樱花yy私人影院亚洲| 亚洲欧洲精品一区| 亚洲一二区在线| 久久激情视频| 欧美国产精品一区| 一卡二卡3卡四卡高清精品视频| 亚洲天堂网在线观看| 久久av一区二区三区漫画| 欧美91大片| 国产精品久久久久久超碰| 狠狠干成人综合网| 99精品免费视频| 久久精品观看| 亚洲黄一区二区| 亚洲欧美精品suv| 欧美大片一区二区| 国产精品影音先锋| 亚洲欧洲日本一区二区三区| 亚洲欧美国产日韩中文字幕| 久久视频在线免费观看| 亚洲免费av网站| 久久免费偷拍视频| 国产精品成人一区二区三区夜夜夜 | 裸体歌舞表演一区二区| 亚洲精品乱码视频| 欧美在线观看日本一区| 欧美日韩你懂的| 精久久久久久久久久久| 亚洲一区二区免费| 欧美1区2区3区| 亚洲欧美日韩一区二区| 欧美激情欧美激情在线五月| 国产一级揄自揄精品视频| 一本久久青青| 欧美插天视频在线播放| 亚洲一区二区网站| 欧美精品福利| 亚洲国产日韩美| 久久天天躁狠狠躁夜夜av| 中文一区在线| 欧美日韩国产不卡| 在线播放豆国产99亚洲| 欧美一级久久久| 99热在这里有精品免费| 欧美成人综合| 亚洲高清二区| 久久亚洲欧美| 亚洲综合日韩中文字幕v在线| 欧美紧缚bdsm在线视频| 136国产福利精品导航网址应用 | 久久综合九色综合欧美狠狠| 亚洲美女黄色片| 欧美大片免费| 亚洲高清久久久| 免费人成网站在线观看欧美高清| 午夜精品久久久久久久| 国产精品视频99| 亚洲视屏在线播放| 亚洲精品午夜精品| 免费成人黄色片| 激情视频一区二区| 久久综合伊人77777尤物| 欧美在线视频在线播放完整版免费观看 | 91久久久一线二线三线品牌| 麻豆freexxxx性91精品| 亚洲成色www久久网站| 久久综合狠狠| 老鸭窝亚洲一区二区三区| 一区在线播放视频| 男女精品网站| 女人香蕉久久**毛片精品| 亚洲第一福利社区| 欧美肥婆bbw| 欧美激情一区二区久久久| 日韩视频在线永久播放| 亚洲精品日日夜夜| 欧美日韩一区二区免费在线观看| 一本色道久久加勒比88综合| 亚洲免费av网站| 国产精品久久久久久久久久三级| 亚洲欧美激情诱惑| 午夜欧美理论片| 伊人色综合久久天天五月婷| 欧美国产免费| 欧美猛交免费看| 亚洲综合第一| 久久成年人视频| 91久久综合亚洲鲁鲁五月天| 亚洲精品国偷自产在线99热| 欧美色视频日本高清在线观看| 亚洲淫性视频| 欧美一区二区免费观在线| 亚洲成人在线免费| 亚洲精品美女在线观看| 欧美性猛交99久久久久99按摩 | 国产精品欧美久久久久无广告| 欧美在线日韩精品| 久久综合亚洲社区| 亚洲手机成人高清视频| 性欧美超级视频| 最新国产成人在线观看| 99热免费精品| 精品av久久707| 99国产精品视频免费观看一公开| 国产嫩草一区二区三区在线观看| 女人色偷偷aa久久天堂| 欧美性大战久久久久久久| 久久久精品国产免费观看同学|