以前看《数据结构与算法--c++版》,写的一个二叉搜索树,贴在这,留做纪念!
 #include <queue>
#include <queue>
 #include <stack>
#include <stack>
 #include <istream>
#include <istream>
 using namespace std;
using namespace std;

 #ifndef BINARY_SEARCH_TREE
#ifndef BINARY_SEARCH_TREE
 #define BINARY_SEARCH_TREE
#define BINARY_SEARCH_TREE


 /**//**堆栈*/
/**//**堆栈*/
 template<class T> class Stack : public stack<T>
template<class T> class Stack : public stack<T>


 {
{
 public:
public:
 T pop()
    T pop()

 
     {
{
 T temp = stack<T>::top();
        T temp = stack<T>::top();
 stack<T>::pop();
        stack<T>::pop();
 return temp;
        return temp;
 }
    }
 };
};


 /**//***
/**//***
 队列
队列
 */
*/
 template<class T> class Queue : public queue<T>
template<class T> class Queue : public queue<T>


 {
{
 public:
public:
 T dequeue()
    T dequeue()

 
     {
{
 T temp = queue<T>::front();
        T temp = queue<T>::front();
 queue<T>::pop();
        queue<T>::pop();
 return temp;
        return temp;
 }
    }
 void enqueue(const T& el )
    void enqueue(const T& el )

 
     {
{
 queue<T>::push( el );
        queue<T>::push( el );
 }
    }
 };
};


 /**//**
/**//**
 二叉树节点
二叉树节点
 */
*/
 template<class T> class BSTNode
template<class T> class BSTNode


 {
{
 public:
public:
 BSTNode()
    BSTNode()

 
     {
{
 left_ = right_ = 0;
        left_ = right_ = 0;
 }
    }
 BSTNode( const T& el, BSTNode<T>* l = 0, BSTNode<T>* r = 0 )
    BSTNode( const T& el, BSTNode<T>* l = 0, BSTNode<T>* r = 0 )

 
     {
{
 value_ = el;
        value_ = el;
 left_ = l;
        left_ = l;
 right_ = r;
        right_ = r;
 }
    }

 T Value()
    T Value()

 
     {
{
 return value_;
        return value_;
 }
    }
 void SetValue( const T& vl )
    void SetValue( const T& vl )

 
     {
{
 value_ = vl;
        value_ = vl;
 }
    }

 BSTNode<T>* Left()
    BSTNode<T>* Left()

 
     {
{
 return left_;
        return left_;
 }
    }
 void SetLeft( BSTNode<T>* left )
    void SetLeft( BSTNode<T>* left )

 
     {
{
 left_ = left;
        left_ = left;
 }
    }

 BSTNode<T>* Right()
    BSTNode<T>* Right()

 
     {
{
 return right_;
        return right_;
 }
    }
 void SetRight( BSTNode<T>* right )
    void SetRight( BSTNode<T>* right )

 
     {
{
 right_ = right;
        right_ = right;
 }
    }

 private:
private:
 T value_;
    T value_;
 BSTNode<T>* left_;
    BSTNode<T>* left_;
 BSTNode<T>* right_;
    BSTNode<T>* right_;
 };
};


 /**//**
/**//**
 搜索二叉树的定义
搜索二叉树的定义
 */
*/
 template<class T> class BST
template<class T> class BST


 {
{
 private:
private:
 //根节点
    //根节点
 BSTNode<T>* root_;
    BSTNode<T>* root_;
 //节点数量
    //节点数量
 int node_count_;
    int node_count_;
 public:
public:

 /**///////////////////////////////////////////////////////////////////////////
    /**///////////////////////////////////////////////////////////////////////////
 //构造析构
    //构造析构

 BST()
    BST() {
{
 root_ = 0;
        root_ = 0;
 node_count_ = 0;
        node_count_ = 0;
 }
    }
 virtual ~BST()
    virtual ~BST()

 
     {
{
 Clear();
        Clear();
 }
    }


 /**///////////////////////////////////////////////////////////////////////////
    /**///////////////////////////////////////////////////////////////////////////
 //公有方法
    //公有方法
 template<typename U> friend ostream& operator << ( ostream& os, const BSTNode<U>* root );
    template<typename U> friend ostream& operator << ( ostream& os, const BSTNode<U>* root );

 void Clear()
    void Clear()

 
     {
{
 Clear( root_);
        Clear( root_);
 root_ = 0;
        root_ = 0;
 }
    }

 /**//***
    /**//***
 当前搜索树是否为空
    当前搜索树是否为空
 */
    */
 bool isEmpty() const
    bool isEmpty() const

 
     {
{
 return root_ == 0;
        return root_ == 0;
 }
    }


 /**//**
    /**//**
 获取节点总数量
    获取节点总数量
 */
    */
 int GetNodeCount() const
    int GetNodeCount() const

 
     {
{
 return node_count_;
        return node_count_;
 }
    }


 /**//**
    /**//**
 获取树的根节点
    获取树的根节点
 */
    */
 const BSTNode<T>* GetRoot() const
    const BSTNode<T>* GetRoot() const

 
     {
{
 return root_;
        return root_;
 }
    }

 //前序遍历
    //前序遍历
 void PreOrder()
    void PreOrder()

 
     {
{
 RecursionPreOrder(root_);
        RecursionPreOrder(root_);
 }
    }
 //中序遍历
    //中序遍历
 void InOrder()
    void InOrder()

 
     {
{
 RecursionInOrder(root_);
        RecursionInOrder(root_);
 }
    }
 //后序遍历
    //后序遍历
 void PostOrder()
    void PostOrder()

 
     {
{
 RecursionPostOrder(root_);
        RecursionPostOrder(root_);
 }
    }
 //morris中序遍历
    //morris中序遍历
 void MorrisInOrder()
    void MorrisInOrder()

 
     {
{
 BSTNode<T>* cur_node = root_;
        BSTNode<T>* cur_node = root_;
 while ( cur_node != NULL )
        while ( cur_node != NULL )

 
         {
{
 //没有左节点,访问节点,并转向右节点
            //没有左节点,访问节点,并转向右节点
 if ( cur_node->Left() == NULL )
            if ( cur_node->Left() == NULL )

 
             {
{
 VisitNode(cur_node);
                VisitNode(cur_node);
 cur_node = cur_node->Right();
                cur_node = cur_node->Right();
 }
            }
 else
            else

 
             {
{
 //退化树
                //退化树
 BSTNode<T>* temp = cur_node->Left();
                BSTNode<T>* temp = cur_node->Left();
 while ( temp ->Right() != NULL && temp->Right() != cur_node )
                while ( temp ->Right() != NULL && temp->Right() != cur_node )

 
                 {
{
 //找到左节点的最右节点
                    //找到左节点的最右节点
 temp = temp->Right();
                    temp = temp->Right();
 }
                }
 if ( temp->Right() == 0 )
                if ( temp->Right() == 0 )

 
                 {
{
 //给该节点成为它的左子节点最右侧节点的右子节点
                    //给该节点成为它的左子节点最右侧节点的右子节点
 temp->SetRight( cur_node );
                    temp->SetRight( cur_node );
 //cur_node.left现在为根节点,原根节点已经成为temp的右子节点。
                    //cur_node.left现在为根节点,原根节点已经成为temp的右子节点。
 cur_node = cur_node->Left();
                    cur_node = cur_node->Left();
 }
                }
 else
                else

 
                 {
{
 //退化完成,访问刚转换完的节点,即原根节点的左节点
                    //退化完成,访问刚转换完的节点,即原根节点的左节点
 VisitNode(cur_node);
                    VisitNode(cur_node);
 //恢复树
                    //恢复树
 temp->SetRight( 0 );
                    temp->SetRight( 0 );
 cur_node = cur_node->Right();
                    cur_node = cur_node->Right();
 }
                }
 }
            }
 }
        }
 }
    }

 //前序遍历--非递归实现
    //前序遍历--非递归实现
 void NonRecursionPreOrder()
    void NonRecursionPreOrder()

 
     {
{
 //使用堆栈
        //使用堆栈
 BSTNode<T>* cur_node = root_;
        BSTNode<T>* cur_node = root_;
 Stack<BSTNode<T>*> nodeStack;
        Stack<BSTNode<T>*> nodeStack;
 nodeStack.push( root_ );
        nodeStack.push( root_ );
 while ( nodeStack.size() != 0 || cur_node != NULL )
        while ( nodeStack.size() != 0 || cur_node != NULL )

 
         {
{
 while ( cur_node != NULL )
            while ( cur_node != NULL )

 
             {
{
 //访问当前节点
                //访问当前节点
 VisitNode( cur_node );
                VisitNode( cur_node );
 //压左子节点
                //压左子节点
 cur_node = cur_node->Left();
                cur_node = cur_node->Left();
 if ( cur_node != NULL )
                if ( cur_node != NULL )

 
                 {
{
 nodeStack.push( cur_node );
                    nodeStack.push( cur_node );
 }
                }
 }
            }
 if( nodeStack.size() != 0 )
            if( nodeStack.size() != 0 )

 
             {
{
 cur_node = nodeStack.pop();
                cur_node = nodeStack.pop();
 cur_node = cur_node->Right();
                cur_node = cur_node->Right();
 }
            }
 }
        }
 }
    }

 //中序遍历--非递归实现
    //中序遍历--非递归实现
 void NonRecursionInOrder()
    void NonRecursionInOrder()

 
     {
{
 //使用堆栈
        //使用堆栈
 BSTNode<T>* cur_node = root_;
        BSTNode<T>* cur_node = root_;
 Stack<BSTNode<T>*> nodeStack;
        Stack<BSTNode<T>*> nodeStack;
 nodeStack.push( root_ );
        nodeStack.push( root_ );
 while ( nodeStack.size() != 0 )
        while ( nodeStack.size() != 0 )

 
         {
{
 while ( cur_node != NULL )
            while ( cur_node != NULL )

 
             {
{
 //压左子节点
                //压左子节点
 cur_node = cur_node->Left();
                cur_node = cur_node->Left();
 if ( cur_node != NULL )
                if ( cur_node != NULL )

 
                 {
{
 nodeStack.push( cur_node );
                    nodeStack.push( cur_node );
 }
                }
 }
            }
 cur_node = nodeStack.pop();
            cur_node = nodeStack.pop();
 //访问当前节点
            //访问当前节点
 VisitNode( cur_node );
            VisitNode( cur_node );
 cur_node = cur_node->Right();
            cur_node = cur_node->Right();
 if ( cur_node != NULL )
            if ( cur_node != NULL )

 
             {
{
 nodeStack.push( cur_node );
                nodeStack.push( cur_node );
 }
            }
 }
        }
 }
    }

 //后序遍历--非递归实现
    //后序遍历--非递归实现
 void NonRecursionPostOrder()
    void NonRecursionPostOrder()

 
     {
{
 BSTNode<T>* cur_node = root_;
        BSTNode<T>* cur_node = root_;
 BSTNode<T>* prev_node = NULL;
        BSTNode<T>* prev_node = NULL;
 Stack<BSTNode<T>*> nodeStack;
        Stack<BSTNode<T>*> nodeStack;
 nodeStack.push( root_ );
        nodeStack.push( root_ );
 while ( nodeStack.size() != 0 )
        while ( nodeStack.size() != 0 )

 
         {
{
 //左边节点压栈
            //左边节点压栈
 while ( cur_node != NULL )
            while ( cur_node != NULL )

 
             {
{
 cur_node = cur_node->Left();
                cur_node = cur_node->Left();
 if ( cur_node != 0 )
                if ( cur_node != 0 )

 
                 {
{
 nodeStack.push( cur_node );
                    nodeStack.push( cur_node );
 }
                }
 }
            }
 //左边的栈保存完毕
            //左边的栈保存完毕
 //开始退栈
            //开始退栈
 cur_node = nodeStack.pop();
            cur_node = nodeStack.pop();
 //左子树在上面的循环已经处理结束
            //左子树在上面的循环已经处理结束
 //如果没有右子树,则访问当前节点
            //如果没有右子树,则访问当前节点
 //如果右子树已经访问过,则访问当前节点。
            //如果右子树已经访问过,则访问当前节点。
 if ( cur_node->Right() != 0 &&
            if ( cur_node->Right() != 0 &&
 prev_node != cur_node->Right() )
            prev_node != cur_node->Right() )

 
             {
{
 //再次保存当前节点
                //再次保存当前节点
 nodeStack.push( cur_node );
                nodeStack.push( cur_node );
 nodeStack.push( cur_node->Right() );
                nodeStack.push( cur_node->Right() );
 }
            }
 else
            else

 
             {
{
 prev_node = cur_node;
                prev_node = cur_node;
 VisitNode( cur_node );
                VisitNode( cur_node );
 }
            }
 cur_node = cur_node->Right();
            cur_node = cur_node->Right();
 }
        }
 }
    }

 /**//**
    /**//**
 搜索
    搜索
 */
    */
 BSTNode<T>* Search(const T& el )
    BSTNode<T>* Search(const T& el )

 
     {
{
 BSTNode<T>* search_node = root_;
        BSTNode<T>* search_node = root_;
 while ( search_node != 0 )
        while ( search_node != 0 )

 
         {
{
 if ( search_node->Value() == el )
            if ( search_node->Value() == el )

 
             {
{
 return search_node;
                return search_node;
 }
            }
 if ( el > search_node->Value() )
            if ( el > search_node->Value() )

 
             {
{
 search_node = search_node->Right();
                search_node = search_node->Right();
 }
            }
 else
            else

 
             {
{
 search_node = search_node->Left();
                search_node = search_node->Left();
 }
            }
 }
        }
 return NULL;
        return NULL;
 }
    }

 /**//**
    /**//**
 插入结点,使用该函数来构造一棵树
    插入结点,使用该函数来构造一棵树
 */
    */
 void Insert( const T& el )
    void Insert( const T& el )

 
     {
{
 BSTNode<T>* new_node = new BSTNode<T>( el );
        BSTNode<T>* new_node = new BSTNode<T>( el );
 ++node_count_;
        ++node_count_;
 //空树,构造根节点
        //空树,构造根节点
 if ( root_ == NULL )
        if ( root_ == NULL )

 
         {
{
 root_ = new_node;
            root_ = new_node;
 return;
            return;
 }
        }
 BSTNode<T>* cur_node = root_;
        BSTNode<T>* cur_node = root_;
 BSTNode<T>* prev_node = NULL;
        BSTNode<T>* prev_node = NULL;
 //查找待插入的位置
        //查找待插入的位置
 while( cur_node != NULL )
        while( cur_node != NULL )

 
         {
{
 prev_node = cur_node;
            prev_node = cur_node;
 if( el > cur_node->Value() )
            if( el > cur_node->Value() )

 
             {
{
 cur_node = cur_node->Right();
                cur_node = cur_node->Right();
 }
            }
 else
            else

 
             {
{
 cur_node = cur_node->Left();
                cur_node = cur_node->Left();
 }
            }
 }
        }

 //插入新构造的节点
        //插入新构造的节点
 if( prev_node->Value() > el )
        if( prev_node->Value() > el )

 
         {
{
 prev_node->SetLeft( new_node );
            prev_node->SetLeft( new_node );
 }
        }
 else
        else

 
         {
{
 prev_node->SetRight( new_node );
            prev_node->SetRight( new_node );
 }
        }

 }
    }
 //合并删除,增加树的高度
    //合并删除,增加树的高度
 void DeleteByMerging( BSTNode<T>* node )
    void DeleteByMerging( BSTNode<T>* node )

 
     {
{
 }
    }
 //复制删除,高度不变,但多次增删会仍会造成树不平衡
    //复制删除,高度不变,但多次增删会仍会造成树不平衡
 void DeleteByCopying( BSTNode<T>* node )
    void DeleteByCopying( BSTNode<T>* node )

 
     {
{
 }
    }
 //根据排序数组构造一颗平衡树
    //根据排序数组构造一颗平衡树
 void Balance( T[], int first, int last )
    void Balance( T[], int first, int last )

 
     {
{
 }
    }
 //DSW平衡算法
    //DSW平衡算法
 void BalanceByDSW()
    void BalanceByDSW()

 
     {
{
 }
    }

 //退化,将树退化为链表,利用左旋转
    //退化,将树退化为链表,利用左旋转
 void Degenerate2ListUsingLeftRotate()
    void Degenerate2ListUsingLeftRotate()

 
     {
{
 BSTNode<T>* temp_node = root_;
        BSTNode<T>* temp_node = root_;
 BSTNode<T>* gr = NULL;
        BSTNode<T>* gr = NULL;
 while( temp_node != NULL )
        while( temp_node != NULL )

 
         {
{
 if( temp_node->Left() != NULL )
            if( temp_node->Left() != NULL )

 
             {
{
 //需要保存left,因为左旋转后
                //需要保存left,因为左旋转后
 //temp_node的左节点已经发生变化,变化为其左节点的右节点了
                //temp_node的左节点已经发生变化,变化为其左节点的右节点了
 BSTNode<T>* cur_node = temp_node->Left();
                BSTNode<T>* cur_node = temp_node->Left();
 RotateLeft( gr, temp_node, temp_node->Left() );
                RotateLeft( gr, temp_node, temp_node->Left() );
 temp_node = cur_node;
                temp_node = cur_node;
 }
            }
 else
            else

 
             {
{
 gr = temp_node;
                gr = temp_node;
 temp_node = temp_node->Right();
                temp_node = temp_node->Right();
 }
            }
 }
        }
 }
    }

 //退化,将树退化为链表,利用右旋转
    //退化,将树退化为链表,利用右旋转
 void Degenerate2ListUsingRightRotate()
    void Degenerate2ListUsingRightRotate()

 
     {
{
 BSTNode<T>* temp_node = root_;
        BSTNode<T>* temp_node = root_;
 BSTNode<T>* gr = NULL;
        BSTNode<T>* gr = NULL;
 while( temp_node != NULL )
        while( temp_node != NULL )

 
         {
{
 if( temp_node->Right() != NULL )
            if( temp_node->Right() != NULL )

 
             {
{
 //需要保存left,因为左旋转后
                //需要保存left,因为左旋转后
 //temp_node的左节点已经发生变化,变化为其左节点的右节点了
                //temp_node的左节点已经发生变化,变化为其左节点的右节点了
 BSTNode<T>* cur_node = temp_node->Right();
                BSTNode<T>* cur_node = temp_node->Right();
 RotateRight( gr, temp_node, temp_node->Right() );
                RotateRight( gr, temp_node, temp_node->Right() );
 temp_node = cur_node;
                temp_node = cur_node;
 }
            }
 else
            else

 
             {
{
 gr = temp_node;
                gr = temp_node;
 temp_node = temp_node->Left();
                temp_node = temp_node->Left();
 }
            }
 }
        }
 }
    }

 void PrintRight()
    void PrintRight()

 
     {
{
 BSTNode<T>* temp_node = root_;
        BSTNode<T>* temp_node = root_;
 while( temp_node != NULL )
        while( temp_node != NULL )

 
         {
{
 VisitNode( temp_node );
            VisitNode( temp_node );
 temp_node = temp_node->Right();
            temp_node = temp_node->Right();
 }
        }
 }
    }

 void PrintLeft()
    void PrintLeft()

 
     {
{
 BSTNode<T>* temp_node = root_;
        BSTNode<T>* temp_node = root_;
 while( temp_node != NULL )
        while( temp_node != NULL )

 
         {
{
 VisitNode( temp_node );
            VisitNode( temp_node );
 temp_node = temp_node->Left();
            temp_node = temp_node->Left();
 }
        }
 }
    }


 /**////////////////////////////////////////////////////////////////////////
    /**////////////////////////////////////////////////////////////////////////
 //保护方法,提供供子类重写的函数,并给出了默认实现
    //保护方法,提供供子类重写的函数,并给出了默认实现
 protected:
protected:
 //默认访问节点的实现
    //默认访问节点的实现
 virtual void VisitNode( BSTNode<T>* p )
    virtual void VisitNode( BSTNode<T>* p )

 
     {
{
 cout << p->Value() << " ";
        cout << p->Value() << " ";
 }
    }


 /**///////////////////////////////////////////////////////////////////////////
    /**///////////////////////////////////////////////////////////////////////////
 //私有方法
    //私有方法
 private:
private:
 //左旋转
    //左旋转
 void RotateLeft( BSTNode<T>* gr, BSTNode<T>* par, BSTNode<T>* cur )
    void RotateLeft( BSTNode<T>* gr, BSTNode<T>* par, BSTNode<T>* cur )

 
     {
{
 // null point;
        // null point;
 if( par == 0 || cur == 0 )
        if( par == 0 || cur == 0 )

 
         {
{
 return;
            return;
 }
        }
 //relationship is not right;
        //relationship is not right;
 if ( par->Left() != cur )
        if ( par->Left() != cur )

 
         {
{
 return;
            return;
 }
        }

 if( gr != NULL && gr->Right() != par )
        if( gr != NULL && gr->Right() != par )

 
         {
{
 return;
            return;
 }
        }

 if( gr != NULL )
        if( gr != NULL )

 
         {
{
 gr->SetRight( cur );
            gr->SetRight( cur );
 }
        }
 else
        else

 
         {
{
 root_ = cur;
            root_ = cur;
 }
        }
 par->SetLeft( cur->Right() );
        par->SetLeft( cur->Right() );
 cur->SetRight( par );
        cur->SetRight( par );
 }
    }

 //和左旋转完全对称
    //和左旋转完全对称
 void RotateRight( BSTNode<T>* gr,BSTNode<T>* par, BSTNode<T>* cur )
    void RotateRight( BSTNode<T>* gr,BSTNode<T>* par, BSTNode<T>* cur )

 
     {
{
 // null point;
        // null point;
 if( par == 0 || cur == 0 )
        if( par == 0 || cur == 0 )

 
         {
{
 return;
            return;
 }
        }
 //relationship is not right;
        //relationship is not right;
 if ( par->Right() != cur )
        if ( par->Right() != cur )

 
         {
{
 return;
            return;
 }
        }

 if( gr != NULL && gr->Left() != par )
        if( gr != NULL && gr->Left() != par )

 
         {
{
 return;
            return;
 }
        }

 if( gr != NULL )
        if( gr != NULL )

 
         {
{
 gr->SetLeft( cur );
            gr->SetLeft( cur );
 }
        }
 else
        else

 
         {
{
 root_ = cur;
            root_ = cur;
 }
        }
 par->SetRight( cur->Left() );
        par->SetRight( cur->Left() );
 cur->SetLeft( par );
        cur->SetLeft( par );
 }
    }

 //释放内存,删除所有节点
    //释放内存,删除所有节点
 void Clear( BSTNode<T>* root )
    void Clear( BSTNode<T>* root )

 
     {
{
 //递归删除,后续遍历
        //递归删除,后续遍历
 BSTNode<T>* p = root;
        BSTNode<T>* p = root;
 if ( NULL != p )
        if ( NULL != p )

 
         {
{
 Clear( p->Left() );
            Clear( p->Left() );
 Clear( p->Right() );
            Clear( p->Right() );
 delete p;
            delete p;
 }
        }
 }
    }

 //前序遍历
    //前序遍历
 void RecursionPreOrder( BSTNode<T>* p )
    void RecursionPreOrder( BSTNode<T>* p )

 
     {
{
 if ( NULL != p )
        if ( NULL != p )

 
         {
{
 VisitNode(p);
            VisitNode(p);
 RecursionPreOrder( p->Left() );
            RecursionPreOrder( p->Left() );
 RecursionPreOrder( p->Right() );
            RecursionPreOrder( p->Right() );
 }
        }
 }
    }
 //后序遍历
    //后序遍历
 void RecursionPostOrder(BSTNode<T>* p)
    void RecursionPostOrder(BSTNode<T>* p)

 
     {
{
 if ( NULL != p )
        if ( NULL != p )

 
         {
{
 RecursionPostOrder( p->Left() );
            RecursionPostOrder( p->Left() );
 RecursionPostOrder( p->Right() );
            RecursionPostOrder( p->Right() );
 VisitNode(p);
            VisitNode(p);
 }
        }
 }
    }
 //中序遍历
    //中序遍历
 void RecursionInOrder(BSTNode<T>* p)
    void RecursionInOrder(BSTNode<T>* p)

 
     {
{
 if ( NULL != p )
        if ( NULL != p )

 
         {
{
 RecursionInOrder( p->Left() );
            RecursionInOrder( p->Left() );
 VisitNode(p);
            VisitNode(p);
 RecursionInOrder( p->Right() );
            RecursionInOrder( p->Right() );
 }
        }
 }
    }
 };
};

 #endif
#endif

 int main()
int main()


 {
{
 cout << "Hello This is C++ Program Using Code::Block!" << "\r\n";
    cout << "Hello This is C++ Program Using Code::Block!" << "\r\n";
 cout << "this is binary search tree test program" << "\r\n";
    cout << "this is binary search tree test program" << "\r\n";
 BST<int> bst_tree;
    BST<int> bst_tree;
 bst_tree.Insert( 10 );
    bst_tree.Insert( 10 );
 bst_tree.Insert( 5 );
    bst_tree.Insert( 5 );
 bst_tree.Insert( 20 );
    bst_tree.Insert( 20 );
 bst_tree.Insert( 3 );
    bst_tree.Insert( 3 );
 bst_tree.Insert( 7 );
    bst_tree.Insert( 7 );
 cout << bst_tree.GetNodeCount() << "\r\n";
    cout << bst_tree.GetNodeCount() << "\r\n";

 /**//*const BSTNode<int>* bst_root = bst_tree.GetRoot();
    /**//*const BSTNode<int>* bst_root = bst_tree.GetRoot();
 BSTNode<int>* temp = const_cast<BSTNode<int>*>(bst_root);
    BSTNode<int>* temp = const_cast<BSTNode<int>*>(bst_root);
 while( temp != NULL )
    while( temp != NULL )
 {
    {
 cout << temp->Value() << " ";
        cout << temp->Value() << " ";
 if( temp->Value() == 5 )
        if( temp->Value() == 5 )
 {
        {
 temp = temp->Right();
            temp = temp->Right();
 }
        }
 else
        else
 {
        {
 temp = temp->Left();
            temp = temp->Left();
 }
        }
 }*/
    }*/

 cout << "递归前序遍历:";
    cout << "递归前序遍历:";
 bst_tree.PreOrder();
    bst_tree.PreOrder();
 cout << "\r\n";
    cout << "\r\n";

 cout << "递归中序遍历:";
    cout << "递归中序遍历:";
 bst_tree.InOrder();
    bst_tree.InOrder();
 cout << "\r\n";
    cout << "\r\n";

 cout << "递归后序遍历:";
    cout << "递归后序遍历:";
 bst_tree.PostOrder();
    bst_tree.PostOrder();
 cout << "\r\n";
    cout << "\r\n";

 cout << "Morris中序遍历:";
    cout << "Morris中序遍历:";
 bst_tree.MorrisInOrder();
    bst_tree.MorrisInOrder();
 cout << "\r\n";
    cout << "\r\n";

 cout << "非递归前序遍历:";
    cout << "非递归前序遍历:";
 bst_tree.NonRecursionPreOrder();
    bst_tree.NonRecursionPreOrder();
 cout << "\r\n";
    cout << "\r\n";

 cout << "非递归中序遍历:";
    cout << "非递归中序遍历:";
 bst_tree.NonRecursionInOrder();
    bst_tree.NonRecursionInOrder();
 cout << "\r\n";
    cout << "\r\n";

 cout << "非递归后序遍历:";
    cout << "非递归后序遍历:";
 bst_tree.NonRecursionPostOrder();
    bst_tree.NonRecursionPostOrder();
 cout << "\r\n";
    cout << "\r\n";

 cout << "将树退化为链表(左旋转):";
    cout << "将树退化为链表(左旋转):";
 bst_tree.Degenerate2ListUsingLeftRotate();
    bst_tree.Degenerate2ListUsingLeftRotate();
 bst_tree.PrintRight();
    bst_tree.PrintRight();
 cout << "\r\n";
    cout << "\r\n";

 cout << "将树退化为链表(右旋转):";
    cout << "将树退化为链表(右旋转):";
 bst_tree.Degenerate2ListUsingRightRotate();
    bst_tree.Degenerate2ListUsingRightRotate();
 bst_tree.PrintLeft();
    bst_tree.PrintLeft();

 cout << endl;
    cout << endl;

 return 0;
    return 0;
 }
}
