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

emptysoul

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  25 Posts :: 0 Stories :: 23 Comments :: 0 Trackbacks

常用鏈接

留言簿(18)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

查找二叉樹的定義,所有節點的左子樹均比該結點小,右子樹均比該節點大。如下所示為一個正解的查找二叉樹:
               6
          5          7
     1                    9
                      8          10

根據定義,查找二叉樹的節點應包含一個存儲數據,兩個指針,分別指向節點的左、右子樹,如下所示。

struct BNode
{
        BNode(T dat, BNode
* l, BNode* r) : data(dat), left(l), right(r){};
        T data;
        BNode 
*left, *right;
}
對于二叉查找樹,其優點在于快速查找節點,在樹中找到一個結點,只需讓需查找的結點N與樹中節點進行比較,若N比當前結點小,則只需查找節點的左子樹,反之,則只需查找節點的右子樹,直至找到為止,所以其查找總是為一條單一的路徑。
二叉查找樹的實現
BTree.h
#ifndef BTREE_H
#define BTREE_H
#include 
<iostream>
#include 
<queue>

static int findcounts; //用于測試查找某節點的次數
template<class T>
class BTree
{
    
//定義樹節點,包括一個數據,兩個指針
    struct BNode
    
{
        BNode(T dat, BNode
* l, BNode* r) : data(dat), left(l), right(r){};
        T data;
        BNode 
*left, *right;
    }
* root;

    
//插入一個節點,
    void Insert(const T& data, BNode*& p)
    
{
        
if(p == 0)
        
{
            p 
= new BNode(data, 00);
            std::cout 
<< "Insert data=" << data << std::endl;
        }

        
else if(data < p->data)
        
{
            
//插入數據小于父節點數據,插入左子樹
            Insert(data, p->left);
        }

        
else if(data > p->data)
        
{
            
//插入數據小于父節點數據,插入右子樹
            Insert(data, p->right);
        }

    }


    
//先序遍歷
    void PreOrder (BNode* p)
    
{
        
if(p != 0)
        
{
            Print(p);
            PreOrder (p
->left);
            PreOrder (p
->right);
        }

    }


    
//中序遍歷
    void InOrder (BNode* p)
    
{
        
if(p != 0)
        
{
            InOrder (p
->left);
            Print(p);
            InOrder (p
->right);
        }

    }


    
//后序遍歷
    void PostOrder (BNode* p)
    
{
        
if(p != 0)
        
{
            PostOrder (p
->left);
            PostOrder (p
->right);
            Print(p);
        }

    }
    

    
//查找節點
    bool Find(const T& data, BNode* p)
    
{
        
if(p != 0)
        
{
            
if(data == p->data)
            
{
                
return true;
            }

            
else if(data < p->data)
            
{
                findcounts 
++;
                Find(data, p
->left);
            }

            
else
            
{
                findcounts 
++;
                Find(data, p
->right);
            }

        }

        
else
        
{
            
return false;
        }

    }


    
//刪除整棵樹
    void MakeEmpty(BNode* p)
    
{
        
if(p != 0)
        
{
            MakeEmpty(p
->left);
            MakeEmpty(p
->right);
            std::cout 
<< "del " << p->data << ",";
            delete p;
        }

    }

public:
    BTree() : root(
0){}

    
~BTree()
    
{
        MakeEmpty(root);
    }


    
void Insert(const T& data)
    
{
        Insert(data, root);
    }


    
void PreOrder()
    
{
        
//遞歸,前序遍歷
        PreOrder(root);
    }


    
void InOrder()
    
{
        
//遞歸,中序遍歷
        InOrder(root);
    }


    
void PostOrder()
    
{
        
//遞歸,后序遍歷
        PostOrder(root);
    }


    
//層次遍歷,使用隊列的特性實現樹的非遞歸遍歷
    void LevelOrder ()
    
{
        queue
<BNode*> q;
        BNode
* p = root;
        
while(p)
        
{
            Print(p);
            
if(p->left != 0)
            
{
                q.push(p
->left);
            }

            
if(p->right != 0)
            
{
                q.push(p
->right);
            }

            
if (q.empty())
            
{
                
break;
            }

            p 
= q.front();
            q.pop();
        }

    }


    
//打印一個節點值
    void Print(BNode* p)
    
{
        
if(p != 0)
        
{
            std::cout 
<< p->data << ",";
        }

    }


    
//打印一個節點的查找次數
    void PrintStatic()
    
{
        std::cout 
<< findcounts;
    }


    
//遞歸查找一個節點
    bool Find(const T& data)
    
{
        findcounts 
= 0;
        
return Find(data, root);
    }

}
;
#endif
對樹進行測試
Test.cpp
#include <iostream>
#include 
<cstdlib>
#include 
<ctime>
#include 
"BTree.h"

using namespace std;

int main(int argc, char *argv[])
{
    
//隨機生成一棵樹
    BTree<int> tree;
    srand((unsigned)time(NULL));
    
for(int i=0; i<20++i)
    
{
        tree.Insert(rand() 
/ 20);
    }

    cout 
<< "前序:" << endl;
    tree.PreOrder();
    cout 
<< endl;
    cout 
<< "中序" << endl;
    tree.InOrder();
    cout 
<< endl;
    cout 
<< "后序" << endl;
    tree.PostOrder();
    cout 
<< endl;
    cout 
<< "層次" << endl;
    tree.LevelOrder();
    cout 
<< endl;

    
if(tree.Find(14))
    
{
        cout 
<< "14 is in the tree,search for " ;
        tree.PrintStatic();
        cout 
<< endl;
    }

    
else
    
{
        cout 
<< "14 is not in the tree,search for " ;
        tree.PrintStatic();
        cout 
<< endl;
    }


    
return 0;
}

posted on 2008-11-24 20:05 emptysoul 閱讀(1013) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   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>
            久久亚洲一区二区| 黑人操亚洲美女惩罚| 久久精品亚洲精品国产欧美kt∨| 久久久噜噜噜久噜久久| 亚洲综合电影一区二区三区| 欧美成人网在线| 久久一区免费| 国产亚洲一区二区精品| 亚洲视频第一页| 亚洲神马久久| 欧美日本免费| 欧美激情免费观看| 136国产福利精品导航| 欧美在线啊v一区| 久久福利视频导航| 国产色产综合产在线视频| 一本一道久久综合狠狠老精东影业| 亚洲国产精品va在线看黑人动漫 | 欧美亚洲免费| 欧美性猛交99久久久久99按摩| 欧美激情一区二区| 91久久久久| 美日韩在线观看| 欧美激情一区二区三区成人| 亚洲大黄网站| 欧美/亚洲一区| 91久久夜色精品国产网站| 狠狠网亚洲精品| 久久网站热最新地址| 欧美成人在线免费观看| 亚洲激情一区二区三区| 欧美高清日韩| 夜夜嗨av一区二区三区网页| 亚洲天堂久久| 国产欧美精品日韩精品| 欧美亚洲一区二区三区| 老**午夜毛片一区二区三区| 一区二区三区在线视频播放| 久久综合给合久久狠狠狠97色69| 欧美搞黄网站| 在线视频你懂得一区| 国产精品乱码一区二区三区| 亚洲欧美日韩电影| 欧美超级免费视 在线| 亚洲精品视频在线观看免费| 欧美日韩免费一区二区三区视频| 一区二区三区日韩精品| 久久精品日韩欧美| 亚洲国产精品一区二区久| 欧美日韩精品是欧美日韩精品| 亚洲视频一区| 裸体歌舞表演一区二区| 日韩视频免费在线| 国产农村妇女毛片精品久久麻豆| 久久精品午夜| 一本色道久久88精品综合| 久久精品99| 亚洲美女精品一区| 国产精品自在线| 欧美成人免费视频| 午夜老司机精品| 亚洲国产高清一区| 欧美中文在线视频| 亚洲理论电影网| 国产一区二区无遮挡| 欧美黑人多人双交| 欧美在线观看视频一区二区三区| 亚洲国产第一页| 久久久国产精品一区二区中文| 亚洲精品日韩综合观看成人91| 国产精品腿扒开做爽爽爽挤奶网站| 久久久激情视频| 亚洲一区图片| 亚洲理论在线观看| 你懂的成人av| 久久爱另类一区二区小说| 一本一本a久久| 亚洲高清视频在线| 国产性做久久久久久| 欧美三级网页| 欧美成人有码| 久久在精品线影院精品国产| 亚洲免费影视| 一区二区三区黄色| 亚洲国产精品一区在线观看不卡| 久久精品国产精品亚洲综合| 亚洲视频自拍偷拍| 亚洲精品乱码久久久久久日本蜜臀| 黄色成人精品网站| 国产日韩精品在线播放| 欧美日韩在线不卡| 欧美日韩国产区一| 欧美高清视频一区| 女主播福利一区| 久久在线免费观看视频| 久久精品欧洲| 久久久久九九九| 久久精品网址| 久久精品视频一| 久久精品视频在线免费观看| 午夜亚洲福利| 午夜欧美大尺度福利影院在线看| 中文在线资源观看视频网站免费不卡| 91久久精品美女高潮| 亚洲国产高清aⅴ视频| 亚洲成人中文| 欧美日韩精品免费观看视一区二区| 老司机67194精品线观看| 久久久久久婷| 久久尤物视频| 欧美大尺度在线观看| 免费试看一区| 欧美精品免费在线观看| 欧美极品一区| 欧美日韩情趣电影| 国产精品sss| 国产女精品视频网站免费 | 欧美亚洲一区| 久久成人免费网| 久久久www成人免费毛片麻豆| 久久精品网址| 免费在线欧美视频| 亚洲日韩成人| 一区二区三区高清不卡| 亚洲在线国产日韩欧美| 欧美中文字幕第一页| 久久久久久久久岛国免费| 久久综合伊人77777麻豆| 欧美成人黄色小视频| 欧美先锋影音| 国产主播喷水一区二区| 91久久精品www人人做人人爽| 日韩亚洲成人av在线| 午夜性色一区二区三区免费视频| 久久国内精品视频| 欧美风情在线观看| 在线亚洲一区| 久久精品一区中文字幕| 欧美日韩成人精品| 国产一区二区三区高清| 亚洲精品视频在线播放| 香蕉亚洲视频| 欧美激情一区二区三区全黄 | 欧美在线观看视频一区二区| 美女主播视频一区| 国产精品毛片va一区二区三区 | 欧美天堂在线观看| 国内精品视频在线观看| 日韩一级精品| 久久精品综合网| 亚洲看片一区| 久久天天躁狠狠躁夜夜av| 欧美日韩一区二区三区四区五区| 国产亚洲欧美一区二区| 一区二区三区国产精华| 久久伊人免费视频| 亚洲系列中文字幕| 欧美极品一区二区三区| 国产一区二区三区久久悠悠色av| 日韩亚洲欧美高清| 你懂的视频一区二区| 亚洲欧美在线播放| 欧美日韩亚洲高清| 亚洲国产欧美一区| 久久精品一区| 亚洲手机视频| 欧美日韩国产不卡在线看| 在线不卡免费欧美| 久久国产精品黑丝| 在线视频精品一区| 欧美精品福利在线| 亚洲国产精品成人精品| 久久免费视频在线观看| 亚洲一区在线直播| 欧美午夜精品电影| 一本色道婷婷久久欧美| 欧美黑人多人双交| 久热精品在线视频| 伊人成人网在线看| 久久亚洲精品一区二区| 亚洲欧美精品在线观看| 国产精品成人一区二区| 夜夜嗨av色综合久久久综合网| 欧美成人一品| 免费成人高清在线视频| 永久免费视频成人| 免费成人av资源网| 久久人人爽人人爽爽久久| 韩国亚洲精品| 久久久国产一区二区| 性刺激综合网| 国产亚洲视频在线| 久久综合九色欧美综合狠狠| 欧美中文字幕在线播放| 国产欧美亚洲一区| 久久免费精品视频| 久久久噜噜噜| 亚洲国产小视频在线观看| 亚洲电影第三页| 欧美激情2020午夜免费观看|