二叉搜索树(也叫二叉查找树、二叉排序树)

缩写:BST(binary search tree)

定义:一颗二叉树或者是空二叉树,此二叉树具有如下性质

左子树上所有结点的关键字均小于根结点的关键字。

右子树上所有结点的关键字均大于根结点的关键字。

左子树和右子树又各是一颗二叉搜索树。

------->>    左子树结点值<根结点值<右子树结点值

对一颗二叉搜索树进行中序遍历,可以得到一个递增的有序序列

 

二叉搜索树的查找

1.若树非空,目标值与根结点的值比较.

2.若相等则查找成功,若小于根结点,则在左子树上查找,否则在右子树上查找。

3.查找成功,返回结点指针;查找失败返回NULL;

//二叉排序树中查找值为key的结点
BSTNode *BST_search(BSTree T,int key)
{
  while(T!=NULL&&key!=T->key)     //若树空或者等于根结点的值,则循环结束
   {
    if(key<T->key) T=T->lchild;   //小于,则在左子树上查找
    else T=T->rchild;             //大于,则在右子树上查找
   }
    return T;
}

 

二叉搜索树的插入

若原二叉搜索树为空,则直接插入结点。若关键字k小于根结点值,则插到左子树。若关键字k大于根结点值,则插入到右子树。

//在二叉搜索树插入关键字为k的新结点(递归实现)
int BST_Insert(BSTree &T,int k)
{
   if(T==NULL)           //如果原树为空,新插入的结点为根结点
    {
      T=(BSTree)malloc(sizeof(BSTNode));
      T->key=k;
      T->lchild=T->rchild=NULL;
      return 1;          //返回1则说明插入成功
    }

    else if(k==T->key)   //树中存在相同关键字的结点,插入失败
    return 0;
    else if(k<T->key)    //插入到T的左子树
    return BST_Insert(T->lchild,k);
    else                 //插入到T的右子树
    return BST_Insert(T->rchild,k);
}

 

二叉搜索树的删除

1.若被删除结点z是叶子结点,则直接删除,不会破坏二叉排序树的性质

2.若结点z只有一颗左子树或右子树,则让z的子树成为z父结点的子树,替代z的位置。

3.若结点z有左右两颗子树,则令z的直接后继(或直接前驱)替代z,然后从二叉排序树中删去这个直接后继(或直接前驱),这样就转换成了第一或第二种情况。

 

查找效率分析

查找成功的平均查找长度ASL(average search length)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值