算法笔记 二叉搜索树

  • 二叉搜索树(Binary Search Tree,简称 BST)是一种数据结构,用于存储具有可比较键(通常是数字或字符串)的元素

1 结构特点

  • 节点结构:每个节点都有一个键和两个子节点(左子节点和右子节点)。
  • 排序特性
    • 若左子树不空,则左子树上所有节点的值都小于根节点的值

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

    • 左子树和右子树也分别是二叉搜索树。

这样的特性使得二叉搜索树能高效地支持多种查找和动态集合操作。

二叉搜索树有一个重要特性就是他的中序遍历结果一定是有序的

2 二叉搜索树的查找

  • 如果当前节点为空,则搜索失败。

  • 否则,如果当前节点的值等于要查找的值,则直接返回。

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

3 二叉搜索树的插入

首先找到他需要插入的位置,然后再插入

  • 如果当前节点为空,直接创建一个新的节点返回。

  • 如果要插入的值比当前节点小,就往当前节点的左子树查找插入的位置。

  • 如果要插入的值比当前节点大,就往当前节点的右子树查找插入的位置。

4 二叉搜索树的删除

  • 如果删除的是叶子节点,则直接删除
  • 如果删除的节点只有一个子节点,让这个仅有的子节点替代他
  • 如果删除的节点有两个子节点,就需要考虑删除当前节点后子节点该怎么存放
    • 删除有两种实现方式,一种是直接删除需要删除的节点,一种是使用移形换位法
      • 直接删除有个缺点就是会导致树严重不平衡
      • AVL 树和红黑树都是移形换位法

4.1 前驱节点和后驱节点

  • 前驱节点:对一棵二叉树进行中序遍历,遍历后的结果中,当前节点的前一个节点为该节点的前驱节点;

  • 后继节点:对一棵二叉树进行中序遍历,遍历后的结果中,当前节点的后一个节点为该节点的后继节点;

  • 当然,查找一个节点的前驱节点和后继节点不一定需要打印二叉树的中序遍历结果这么麻烦

    • 个节点的前驱节点是他左子树中的最大节点,这个节点就是他左子树往右一直走下去的节点
    • 一个节点的后继节点就是他右子树的最小节点,这个节点就是他右子树往左一直走下去的节点

4.2 直接删除

直接删除的缺点就是会严重破坏树的平衡性

4.2.1 方法1:让待删除节点的右子节点成为他前驱节点的右子节点

4.2.2 方法2:让待删除节点的左子节点成为他后继节点的左子节点

相关推荐
一只爱做笔记的码农3 小时前
【BootstrapBlazor】移植BootstrapBlazor VS工程到Vscode工程,报error blazor106的问题
笔记·学习·c#
木西3 小时前
人间观察:关于健康、善良与选择的思考
笔记
星轨初途3 小时前
数据结构排序算法详解(2)——选择排序(附动图)
c语言·数据结构·经验分享·笔记·b树·算法·排序算法
charlie1145141915 小时前
勇闯前后端Week2:后端基础——Flask API速览
笔记·后端·python·学习·flask·教程
深蓝海拓5 小时前
OpenCV学习笔记之:调整ORB算法的参数以适应不同的图像
笔记·opencv·学习
d111111111d5 小时前
STM32外设--SPI读取W25Q64(学习笔记)硬件SPI
笔记·stm32·单片机·嵌入式硬件·学习
摇滚侠5 小时前
2025最新 SpringCloud 教程,Nacos-配置中心-数据隔离-动态切换环境,笔记18
java·笔记·spring cloud
_Kayo_6 小时前
vue3 computed 练习笔记
前端·vue.js·笔记
TracyCoder1236 小时前
微服务框架选型学习笔记
笔记·学习·微服务
摇滚侠6 小时前
2025最新 SpringCloud 教程,Nacos-注册中心 @LoadBalanced 注解式负载均衡,笔记11
笔记·spring cloud·负载均衡