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

liyuxia713

蹣跚前行者

常用鏈接

統(tǒng)計

Algorithms

C++

最新評論

二叉排序樹

 1//BTreeNode.h 二叉樹結(jié)點抽象類型
 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* 根據(jù)給定的字符串構(gòu)造一個排序二叉樹
  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沒有默認設(shè)置為NULL的構(gòu)造函數(shù)
 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有左子樹,找出左子樹中結(jié)點值最大的節(jié)點temp(最右下角的結(jié)點,也是中序遍歷最后一個結(jié)點,他沒有右子樹)
 73// 用temp的結(jié)點值替換下p的結(jié)點值
 74// 刪除temp(因為temp的右子樹為空,從而直接用其左子樹根代替本身就可達到刪除結(jié)點的目的)
 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        //記錄左子樹中序遍歷的最后一個結(jié)點(值最大的點)
 85        while(temp->rchild != NULL)
 86            temp = temp->rchild;    
 87        //刪除這個結(jié)點,等價于用這個結(jié)點的做子樹代替這個結(jié)點(因為這個結(jié)點沒有右子樹)
 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; //注意這兩行是不能合并在一起的,不然可能會出現(xiàn)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//謂詞函數(shù)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 幸運草 閱讀(1759) 評論(0)  編輯 收藏 引用 所屬分類: Data Structure

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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日韩mv国产网站| 欧美日韩高清不卡| 国产欧美日韩另类视频免费观看| 国产乱码精品一区二区三区忘忧草| 国产精品卡一卡二卡三| 影音先锋中文字幕一区| 99视频超级精品| 亚洲欧美视频在线| 欧美电影在线播放| 亚洲精品国产视频| 亚洲午夜电影在线观看| 久久久国产精品一区| 欧美国内亚洲| 亚洲免费在线视频| 欧美fxxxxxx另类| 国产欧美一区二区白浆黑人| 亚洲国产精品成人一区二区 | 欧美日韩中文字幕在线视频| 国产麻豆日韩| 日韩亚洲国产精品| 久久久综合精品| 一区二区三区免费网站| 久久亚洲精品一区二区| 国产精品视频九色porn| 91久久久亚洲精品| 久久精品国产77777蜜臀| 亚洲精品一区二区三区福利| 久久久久久久激情视频| 国产欧美一区二区精品仙草咪| 日韩亚洲成人av在线| 免费日韩av电影| 午夜精品网站| 国产精品久久久久永久免费观看| 亚洲黄网站在线观看| 久久夜精品va视频免费观看| 亚洲一区国产视频| 国产精品jizz在线观看美国| 亚洲破处大片| 欧美福利影院| 久久这里有精品15一区二区三区| 国产亚洲成精品久久| 午夜免费久久久久| 国产精品99久久99久久久二8| 欧美国产三区| 亚洲黄一区二区| 毛片精品免费在线观看| 久久精品国产综合精品| 激情文学综合丁香| 美女主播一区| 蜜臀va亚洲va欧美va天堂| 亚洲福利国产| 亚洲国产你懂的| 麻豆国产精品777777在线| 激情综合激情| 欧美大香线蕉线伊人久久国产精品| 久久国产精品72免费观看| 精品88久久久久88久久久| 蜜臀av性久久久久蜜臀aⅴ| 久久九九电影| 亚洲国产日韩在线| 亚洲电影观看| 欧美国产日产韩国视频| 99精品福利视频| 99在线精品视频| 国产精品护士白丝一区av| 亚洲欧美三级在线| 欧美在线观看视频一区二区| 精品999在线观看| 91久久国产综合久久91精品网站| 免播放器亚洲一区| 欧美第一黄色网| 亚洲视频一区二区| 中文av一区二区| 国产精品一区视频网站| 久久婷婷久久| 欧美激情国产精品| 亚洲男同1069视频| 久久精品亚洲| 一本色道综合亚洲| 香蕉久久夜色精品| 亚洲免费激情| 欧美一区二区三区久久精品 | 欧美一站二站| 美女国内精品自产拍在线播放| 亚洲人成网站精品片在线观看| 一区二区三区视频观看| 亚洲第一精品久久忘忧草社区| 亚洲美女视频在线观看| 狠狠色狠狠色综合系列| 日韩一区二区久久| 亚洲第一偷拍| 亚洲免费一在线| 夜夜嗨av色一区二区不卡| 久久福利一区| 午夜精品久久久久久久99黑人| 久久综合久久综合久久| 午夜精品国产精品大乳美女| 免费黄网站欧美| 久久久久亚洲综合| 国产精品国产三级国产a| 欧美福利在线| 国产午夜久久久久| 中文国产成人精品| 9i看片成人免费高清| 久久亚裔精品欧美| 久久久久久久综合色一本| 欧美日韩无遮挡| 欧美成人免费观看| 国模套图日韩精品一区二区| 亚洲午夜精品一区二区| 99日韩精品| 欧美二区在线| 欧美黑人国产人伦爽爽爽| 国产综合精品| 亚洲综合电影一区二区三区| 一区二区黄色| 欧美成人午夜77777| 欧美不卡三区| 在线成人激情视频| 久久精品国产v日韩v亚洲 | 亚洲人精品午夜在线观看| 欧美在线视频一区| 久久av一区| 国产午夜精品麻豆| 午夜精品福利电影| 亚欧美中日韩视频| 国产日韩欧美一区二区三区四区| 亚洲宅男天堂在线观看无病毒| 亚洲一区成人| 国产精品美女在线| 亚洲免费视频观看| 久久精品系列| 久久亚洲视频| 亚洲高清在线观看| 亚洲精品激情| 欧美喷潮久久久xxxxx| 亚洲精品一区二区三区樱花| 99精品福利视频| 欧美午夜大胆人体| 午夜精品av| 男女精品视频| 亚洲精品久久久久中文字幕欢迎你| 欧美成人午夜| 一区二区三区久久久| 欧美一级视频| 在线观看成人av电影| 欧美插天视频在线播放| 一本色道久久综合精品竹菊| 性做久久久久久久久| 亚洲高清在线观看| 欧美丝袜第一区| 久久国产精品久久久久久| 欧美国产日韩在线观看| 亚洲最快最全在线视频| 国产欧美一区二区三区沐欲| 久久久亚洲人| 一区二区三区国产在线| 久久成人精品无人区| 亚洲欧洲一区二区天堂久久| 欧美午夜寂寞影院| 久久久777| 一本一本久久| 欧美成人a∨高清免费观看| 一本一本久久a久久精品综合妖精| 国产精品美女久久久浪潮软件 | 一区二区三区高清视频在线观看| 午夜一区二区三区不卡视频| 亚洲国产日韩欧美在线图片| 国产精品久久77777| 蜜臀91精品一区二区三区| 亚洲综合精品四区| 亚洲国产成人午夜在线一区| 久久黄色小说| 一区二区三区欧美激情| 在线成人激情| 国产精品影视天天线| 女女同性精品视频| 欧美在线观看一区二区| 夜夜嗨av一区二区三区四季av| 美女视频黄a大片欧美| 亚洲欧美日韩国产一区| 日韩午夜黄色| 亚洲国产一区视频| 国产午夜亚洲精品不卡| 欧美日韩一区二区视频在线观看| 久久久91精品| 久久国产精品一区二区| 亚洲无人区一区| 亚洲激情第一区| 欧美高清视频一区| 美女啪啪无遮挡免费久久网站| 欧美在线日韩精品| 午夜精品福利一区二区三区av|