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

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>
            欧美国产精品专区| 在线视频欧美精品| 欧美看片网站| 毛片基地黄久久久久久天堂| 久久爱www久久做| 久久精品99国产精品日本| 久久激情视频| 免费久久久一本精品久久区| 欧美成人中文| 欧美午夜无遮挡| 国产午夜精品久久久| 亚洲国产欧美不卡在线观看| 亚洲国产精品va在线看黑人| 亚洲人午夜精品| 午夜一区二区三区在线观看| 久久久天天操| 亚洲高清不卡| 日韩午夜激情| 欧美一区二区三区男人的天堂| 久久久久国产一区二区三区四区| 欧美精品久久99| 欧美在线二区| 亚洲激情欧美| 午夜国产精品视频| 欧美在线高清| 欧美日韩另类丝袜其他| 国产一区二区三区高清在线观看 | 国产精品久久久久永久免费观看| 国产日韩一区二区| 日韩午夜在线播放| 久久国产精品毛片| 亚洲精品午夜| 久久久噜噜噜久噜久久| 欧美色区777第一页| 在线观看亚洲一区| 欧美一区二区女人| 亚洲免费成人av电影| 久久久久久穴| 国产欧美韩国高清| 亚洲一二区在线| 亚洲福利视频专区| 久久久久久久高潮| 国产欧美大片| 欧美一区二粉嫩精品国产一线天| 亚洲日本在线观看| 葵司免费一区二区三区四区五区| 国产精品久久一卡二卡| 在线性视频日韩欧美| 欧美激情一区二区三区成人| 久久精品人人做人人爽| 国产嫩草一区二区三区在线观看| 99精品久久久| 亚洲国产综合视频在线观看| 久久蜜桃香蕉精品一区二区三区| 国产欧美日韩视频在线观看| 亚洲一区欧美激情| 亚洲日本黄色| 欧美人与性动交a欧美精品| 亚洲国产日韩欧美在线99| 久久免费99精品久久久久久| 欧美一区二区三区视频| 国产精品夜夜夜| 欧美一区二区三区的| 在线视频一区二区| 国产精品二区二区三区| 亚洲小说春色综合另类电影| 亚洲免费播放| 国产精品视频自拍| 久久av免费一区| 久久se精品一区精品二区| 国产一区二区三区观看| 久久久久久网| 免费久久久一本精品久久区| 日韩视频免费在线| 亚洲精品免费一区二区三区| 欧美三级电影一区| 午夜久久99| 亚洲欧洲在线观看| 亚洲黄色一区| 欧美日韩综合视频| 亚洲欧美一区二区三区在线| 一区二区三区国产精华| 国产麻豆成人精品| 久久久亚洲欧洲日产国码αv | 欧美a级一区| 日韩视频免费观看高清在线视频 | 嫩草成人www欧美| 欧美11—12娇小xxxx| 99热在线精品观看| 99这里只有久久精品视频| 国产精品久线观看视频| 久久国产夜色精品鲁鲁99| 久久亚洲私人国产精品va| 亚洲精品一区二区三区樱花| 亚洲理论在线观看| 国产亚洲免费的视频看| 欧美成人视屏| 国产精品久久久久久久午夜 | 国产精品草草| 欧美1级日本1级| 国产精品久久久999| 久久视频精品在线| 欧美日韩裸体免费视频| 久久9热精品视频| 欧美福利视频在线| 欧美一区二区三区在线观看| 免费成人av| 久久国内精品自在自线400部| 免费影视亚洲| 久久精品视频亚洲| 欧美日韩精品欧美日韩精品 | 欧美成人精品在线| 久久国产高清| 欧美日韩免费网站| 免费亚洲视频| 国产一区二区三区精品欧美日韩一区二区三区 | 欧美一区二区三区视频在线观看| 美女视频一区免费观看| 久久久久国产一区二区| 欧美日韩一区二| 欧美.日韩.国产.一区.二区| 国产精品综合| 亚洲午夜电影在线观看| 宅男噜噜噜66国产日韩在线观看| 午夜精品久久久久99热蜜桃导演| 欧美午夜在线| 欧美xart系列高清| 狠狠狠色丁香婷婷综合久久五月| 亚洲少妇自拍| 亚洲性感激情| 欧美色另类天堂2015| 亚洲狼人精品一区二区三区| 亚洲精品一区二区三区在线观看| 久久五月天婷婷| 猛干欧美女孩| 亚洲电影免费观看高清完整版| 久久不射电影网| 久久久蜜桃一区二区人| 国内外成人免费激情在线视频网站| 亚洲一区在线观看视频| 午夜精品久久久| 国产精品一区二区在线观看网站| 在线亚洲欧美视频| 亚洲欧美日韩国产成人精品影院| 国产精品99免费看 | 揄拍成人国产精品视频| 久久久久久久国产| 欧美黄色小视频| 亚洲精品免费在线播放| 欧美精品99| 亚洲一区不卡| 欧美在线免费看| 国产自产精品| 久久一区二区精品| 欧美激情一区二区三区在线视频| 亚洲精品午夜| 国产精品久久久久av| 亚久久调教视频| 美女视频网站黄色亚洲| 最近中文字幕日韩精品| 欧美日韩国产小视频在线观看| 一区二区三区.www| 久久久久久999| 91久久国产综合久久| 欧美久久精品午夜青青大伊人| 在线亚洲电影| 裸体一区二区三区| 国产精品99久久久久久久vr| 国产欧美韩日| 欧美本精品男人aⅴ天堂| 一区二区三区日韩精品视频| 久久久久久97三级| 一区二区三区视频在线播放| 国产一区二区三区视频在线观看| 麻豆freexxxx性91精品| 亚洲图片自拍偷拍| 欧美国产激情二区三区| 亚洲免费视频成人| 亚洲精品久久久久久久久久久久 | 久久精品日产第一区二区| 日韩午夜激情电影| 久久中文久久字幕| 一区二区欧美在线| 一区二区视频在线观看| 国产精品成人av性教育| 亚洲国产欧美一区| 男人的天堂亚洲在线| 亚洲第一黄网| 欧美一区二区女人| 中国成人黄色视屏| 91久久黄色| 国自产拍偷拍福利精品免费一| 欧美女激情福利| 久久久欧美精品| 先锋影音久久| 亚洲一区二区三区高清| 一本久久精品一区二区| 亚洲日本成人| 亚洲国产精品成人va在线观看| 久久久精品免费视频|