数据结构与算法-二叉排序树

前言

查找和排序是算法中最基础的两类算法,其或多或少会被应用在其他高阶算法中。每一种算法都可以有多种数据结构作为支撑,比如查找,可以是对于无序顺序表的查找,查找时只能顺序遍历了;可以是有序顺序表的查找,可以进行二分查找;还可以是即将要介绍的二叉排序树的查找,其查找逻辑类似于二分查找,在插入元素时又不需要大量的移动操作。

定义

二叉排序树又叫做二叉查找树,在数的内部维护着一种秩序,即任何子树的左子树都小于该子树的树根,右子树都大于该子树的树根,这样在查找逻辑就会类似二分查找,这种秩序是在插入元素时得到维持的。

由于二叉排序树的特性,其再求最值、Floor、Ceiling时也是有规律的。

最大最小值

Floor和Ceiling

查找Floor(key)的值就是所有<=key的最大值,相反查找Ceiling的值就是所有>=key的最小值,下图是Floor函数的查找示意图:

删除

 缺陷

二叉排序树在搜索逻辑上类似二分查找,实现也比较简单,但与二分查找一样,极端情况下可能会编程顺序查找(如下图的worst case),也正是因为这种缺陷,排序二叉树很少应用于工程,所以才会出现平衡二叉树。

 

转载于:https://www.cnblogs.com/holoyong/p/7243959.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值