《征服数据结构》二叉搜索树(BST)

摘要:

1,二叉搜索树的介绍

2,二叉搜索树的查找

3,二叉搜索树的插入

4,二叉搜索树的删除

1,二叉搜索树的介绍

二叉搜索树(Binary Search Tree,简称:BST)也叫二叉查找树,他是具有下列性质的一种二叉树:

1,若左子树不空,则左子树上所有节点的值都小于根节点的值;

2,若右子树不空,则右子树上所有节点的值都大于根节点的值;

3,任意节点的子树也都是二叉搜索树;

二叉搜索树有一个重要特性就是他的 中序遍历结果一定是有序的,所以它又叫二叉排序树。如上图所示,二叉搜索树的中序遍历结果是 [1,3,4,6,8,9] 。

二叉搜索树的优势在于查找,越平衡查找效率越高,时间复杂度可以达到O(logn),如果二叉搜索树退化成一个链表,时间复杂度就会达到O(n)。

为了防止二叉搜索树退化成链表,可以通过左旋和右旋让它尽可能保持平衡,这个就是我们后面要介绍的 AVL 树和红黑树。

2,二叉搜索树的查找

根据二叉搜索树的特性,每次只需要和当前节点比较,确定是往左边查找还是往右边查找,查找步骤如下:

1,如果当前节点为空,则查找失败。

2,否则,如果当前节点的值等于要查找的值,则查找成功。

3,否则,如果要查找的值比当前节点小,就往当前节点的左子树找。如果要查找的值比当前节点值大,就往当前节点的右子树找。

相关推荐
vir024 小时前
P1928 外星密码(dfs)
java·数据结构·算法·深度优先·1024程序员节
胡萝卜3.04 小时前
C++ list核心接口与实战技巧
数据结构·c++·list·list使用
仟千意5 小时前
数据结构:排序篇
数据结构
脚踏实地的大梦想家6 小时前
【Go】P8 Go 语言核心数据结构:深入解析切片 (Slice)
开发语言·数据结构·golang
蒙奇D索大8 小时前
【数据结构】数据结构核心考点:AVL树删除操作详解(附平衡旋转实例)
数据结构·笔记·考研·学习方法·改行学it·1024程序员节
大数据张老师10 小时前
数据结构——平衡二叉树
数据结构·算法·查找
大数据张老师11 小时前
数据结构——BF算法
数据结构·算法·1024程序员节
Yupureki11 小时前
从零开始的C++学习生活 14:map/set的使用和封装
c语言·数据结构·c++·学习·visual studio·1024程序员节
一匹电信狗11 小时前
【LeetCode_876_2.02】快慢指针在链表中的简单应用
c语言·数据结构·c++·算法·leetcode·链表·stl
胖咕噜的稞达鸭12 小时前
算法入门---专题二:滑动窗口2(最大连续1的个数,无重复字符的最长子串 )
c语言·数据结构·c++·算法·推荐算法·1024程序员节