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

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>
            亚洲毛片视频| 小辣椒精品导航| 亚洲高清在线| 亚洲欧美综合国产精品一区| 亚洲乱码国产乱码精品精| 久久成人免费电影| 亚洲免费视频网站| 欧美日韩色综合| 亚洲国产日日夜夜| 红桃视频一区| 欧美亚洲专区| 久久国产精品色婷婷| 国产精品爱啪在线线免费观看| 亚洲国产福利在线| 亚洲国产日韩欧美综合久久| 久久国产精品电影| 久久精品综合网| 国产欧美一区二区三区在线看蜜臀 | 国产精品入口| 99re成人精品视频| 9色精品在线| 欧美精品一区在线| 亚洲日本欧美| 99精品国产高清一区二区| 欧美成人资源| 99re亚洲国产精品| 亚洲午夜久久久| 国产精品黄视频| 日韩亚洲国产欧美| 亚洲尤物在线视频观看| 国产精品美女午夜av| 亚洲中午字幕| 久久性色av| 亚洲激情成人网| 欧美精品 国产精品| 99精品热视频| 小黄鸭精品密入口导航| 国产午夜久久久久| 久久五月激情| 亚洲国产片色| 亚洲一区网站| 国内精品写真在线观看| 久久综合电影| 99综合在线| 久久精品99无色码中文字幕| 在线成人激情黄色| 欧美日韩一二三四五区| 亚洲欧美日韩精品久久久| 久久一区二区三区国产精品| 亚洲精品一区二区在线| 欧美特黄一级| 久久精品一本| 亚洲精品日韩欧美| 久久精品亚洲国产奇米99| 亚洲第一精品福利| 欧美性色综合| 久久久久久婷| 中国成人在线视频| 免费短视频成人日韩| 一区二区三区视频在线观看 | 国内精品久久久久久久影视麻豆 | 欧美中文字幕视频| 亚洲经典视频在线观看| 欧美日韩三级视频| 亚洲图片欧洲图片av| 亚洲一区二区三区免费观看 | 亚洲精品国产系列| 国产精品美女久久久久久久 | 久久久青草青青国产亚洲免观| 亚洲国产专区校园欧美| 欧美在线视频免费播放| 日韩视频在线观看| 国产亚洲午夜| 欧美网站大全在线观看| 久久综合狠狠综合久久综合88| 一区二区三区**美女毛片| 免费成人黄色片| 午夜一区不卡| 一二美女精品欧洲| 亚洲国产精品久久久久| 国产日韩精品视频一区二区三区| 欧美极品一区二区三区| 久久久亚洲人| 亚久久调教视频| 亚洲少妇一区| 99精品国产高清一区二区| 欧美成人激情视频| 久久影音先锋| 久久精品首页| 久久不射中文字幕| 性欧美激情精品| 亚洲欧美日韩综合| 一区二区三区导航| 亚洲剧情一区二区| 亚洲精品极品| 亚洲精品一区二区三区av| 亚洲第一在线视频| 禁断一区二区三区在线| 国产一区二区三区高清播放| 国产精品网红福利| 国产精品大片免费观看| 欧美视频中文在线看| 欧美日韩成人一区二区| 欧美成人免费视频| 欧美成人中文字幕| 欧美激情综合网| 欧美精品一区二区三区在线看午夜| 老色鬼久久亚洲一区二区| 久久九九久精品国产免费直播 | 日韩网站在线| 亚洲精品中文字幕在线观看| 亚洲三级国产| 日韩视频在线一区| 一区二区三区www| 一区二区三区高清视频在线观看| 99视频精品全国免费| 在线亚洲一区观看| 亚洲欧美在线高清| 久久福利影视| 久久久精品午夜少妇| 麻豆成人在线播放| 欧美日韩不卡| 国产精品一区二区你懂得| 国产午夜精品一区二区三区欧美 | 亚洲人成在线观看| 一本色道久久综合亚洲精品婷婷| 亚洲视频在线一区| 欧美在线日韩| 毛片精品免费在线观看| 欧美日本高清| 国产日韩精品视频一区二区三区| 狠狠色香婷婷久久亚洲精品| 亚洲国产清纯| 亚洲欧美国产精品桃花| 久久久视频精品| 亚洲高清在线视频| 亚洲特色特黄| 久久一日本道色综合久久| 欧美日韩国产一区二区| 国产人成一区二区三区影院| 在线精品国产欧美| 亚洲主播在线观看| 麻豆av福利av久久av| 亚洲精品在线免费观看视频| 午夜日韩视频| 欧美激情亚洲精品| 国产一区二区高清不卡| 亚洲另类一区二区| 久久国产视频网站| 亚洲精品无人区| 久久精品亚洲精品国产欧美kt∨| 欧美日本韩国在线| 伊人久久大香线| 亚洲自拍电影| 亚洲福利视频三区| 欧美一区网站| 欧美调教视频| 91久久久久| 久久九九久久九九| 在线中文字幕不卡| 欧美高清在线一区| 亚洲成色www8888| 欧美在线首页| 一本色道久久| 欧美激情1区2区3区| 激情久久久久久久| 欧美在线视频日韩| 一区二区欧美国产| 欧美国产精品久久| 揄拍成人国产精品视频| 欧美一区二区日韩| 亚洲一区成人| 欧美日韩亚洲另类| 亚洲伦理在线免费看| 猛男gaygay欧美视频| 久久成人免费| 国产日韩精品视频一区| 亚洲欧美日韩在线综合| 99在线精品免费视频九九视| 欧美激情亚洲| 亚洲精品综合久久中文字幕| 女女同性精品视频| 久久久之久亚州精品露出| 国产一区二区三区四区在线观看| 午夜电影亚洲| 宅男噜噜噜66一区二区66| 欧美三日本三级少妇三2023| 一本一本大道香蕉久在线精品| 亚洲国产视频a| 欧美精品色一区二区三区| 亚洲精品在线免费观看视频| 亚洲观看高清完整版在线观看| 美女啪啪无遮挡免费久久网站| 好吊日精品视频| 蜜桃av噜噜一区| 免费成人毛片| 一本色道久久88精品综合| 亚洲美女少妇无套啪啪呻吟| 欧美肥婆在线| 亚洲午夜国产成人av电影男同|