二叉排序树

二叉排序树(Binary Sort Tree),又被称为二叉查找树,它是一棵空树,或是具有以下性质的树:
①若它的左子树不为空,则它的左子树上的所有结点的值小于根节点的值;
②若它的右子树不为空,则它的右子树上的所有结点的值大于根节点的值;
③它的左右子树也是二叉排序树;

c++实现

#ifndef BST_H_
#define BST_H_
#include <stack>
using namespace std;
#define NULL 0
template<typename T>
struct BSTnode
{
    T m_data;              //关键字  
    BSTnode<T>  *m_left;   //左孩子指针  
    BSTnode<T>  *m_right;  //右孩子指针  

};

template<typename T>
class BSTree
{
public:
    BSTree(T data=NULL);
    ~BSTree();
    bool SearchTree(BSTnode<T> *root, T key, BSTnode<T> *parent, BSTnode<T> *&place);
    BSTnode<T> *& Getroot();
    bool InsertTree(T key);
    bool DeleteTree(BSTnode<T> * & place);
    bool DeleteBST(BSTnode<T> *&root, T key);
    void DestoryTree(BSTnode<T> *root);
    void InOrderTraverse(BSTnode<T>* node);
    //中序遍历
    void InOrderTraverse2();
    //非递归中序遍历
private:
    BSTnode<T> *m_root;
};
template<typename T>
BSTree<T>::BSTree(T data)
{
    m_root = new BSTnode<T>;
    m_root->m_data = data;
    m_root->m_left =
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值