二叉排序树(BST)

二叉排序树,又叫二叉查找树,它或者是一棵空树;或者是具有以下性质的二叉树:
1. 若它的左子树不空,则左子树上所有节点的值均小于它的根节点的值;
2. 若它的右子树不空,则右子树上所有节点的值均大于它的根节点的值;
3. 它的左右子树也分别为二叉排序树。

 

1.1  排序二叉树之插入操作 

      已知一个关键字值为key的结点s,若将其插入到二叉排序树中,只要保证插入后仍符合二叉排序树的定义即可。插入可以用下面的方法进行: 
    (1)若二叉排序树是空树,则key成为二叉排序树的根; 
    (2)若二叉排序树非空,则将key与二叉排序树的根进行比较。如果key的值等于根结点的值,则停止插入;如果key的值小于根结点的值,则将key插入左子树,如果key的值大于根结点的值,则将key插入右子树。

    (3)重复步骤2,直到找到合适的插入位置。

1.2  排序二叉树之删除操作

当程序从排序二叉树中删除一个节点之后,为了让它依然保持为排序二叉树,程序必须对该排序二叉树进行维护。维护可分为如下几种情况:

(1)被删除的节点是叶子节点,则只需将它从其父节点中删除即可。

(2)如果待删除节点左子树存在右子树不存在,或者左子树不存在右子树存在。直接将其子树中存在的一边候补上来即可。

(3)若被删除节点 p 的左、右子树均非空,有两种做法:

  • 将 p 右子树pR转到左子树pL的最大节点(P节点中序前趋)(如果p在q的左边则相反操作),把问题直接转换用问题(2)
  • 以 p 节点的中序前趋或后继替代 p 所指节点,然后再从原排序二叉树中删去中序前趋或后继节点即可,把问题直接转换成情(1)

    1.3  排序二叉树之遍历

  • 对于二叉树,有深度遍历和广度遍历,深度遍历有前序、中序以及后序三种遍历方法,广度遍历即我们寻常所说的层次遍历è¿éåå¾çæè¿°

  • 前序遍历:根结点 ---> 左子树 ---> 右子树     GDAFEMHZ

  • 中序遍历:左子树---> 根结点 ---> 右子树 ADEFGHMZ

  • 后序遍历:左子树 ---> 右子树 ---> 根结点   AEFDHZMG

  • 层次遍历:仅仅需按层次遍历就可  GDMAFHZE

 

 1.4  排序二叉树之旋转操作

    以pivot为轴心向左旋转--左旋

 

以pivot为轴心向右旋转--右旋

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值