【JS数据结构与算法】二叉搜索树

目录

一、什么是二叉搜索树

二、二叉搜索树的优点


一、什么是二叉搜索树

二叉搜索树(BST , Binary Search Tree),也称为二叉排序树或二叉查找树。

二叉搜索树是一棵二叉树,也是可以为空。

如果二叉搜索树不为空,那么,满足以下条件:

  • 非空左子树的所有键值小于其根节点的键值。
  • 非空右子树的所有键值大于其根节点的键值。
  • 左右子树本身也是二叉搜索树。

二、二叉搜索树的优点

假设在图 a 中,我们想要查找24这个结点,首先是从根 18 开始找,发现 24 比 18 要大,根据二叉搜索树的特点:非空右子树的所有键值大于其根节点的键值。所以就直接排除了左边的所有元素,直接进去右子树,再比较 30 发现 24 比 30 小,所以找到了 30 的左子树即是 24 了。

那我们再认识一下二分法查找的思想。

二分查找法,也称为折半,对于一个有序数组。

(1)首先,从数组的中间元素开始搜索,如果该元素是目标元素,则搜索结束,否则执行下一步。

(2)如果目标元素大于/小于中间元素,则在数组大于/小于中间元素的那一半区域查找,然后重复步骤(1)的操作。

(3)如果某一步数组为空,则表示找不到目标元素。

类似地二叉搜索树就是二分查找的思想,时间复杂度可以缩小为O(logn)

 

总结:二叉搜索树是在插入的时候规范一棵树的结构以及规范数据的存放,使得方便了后续的查找以及修改操作,效率大大提升。

三、二叉搜索树的缺点

  • 删除操作时并不是仅仅删除一个结点,还要考虑结点数值的问题
  • 在存储一个有序的线性表时,会造成空间浪费。
  • 对于一组大量数据出现局部有序的情况,会让一棵树变得一边倒,即产生不平衡的情况。(这就有了平衡树)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值