算法笔记 二叉搜索树

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

1 结构特点

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

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

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

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

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

2 二叉搜索树的查找

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

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

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

3 二叉搜索树的插入

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

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

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

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

4 二叉搜索树的删除

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

4.1 前驱节点和后驱节点

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

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

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

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

4.2 直接删除

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

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

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

相关推荐
_李小白8 小时前
【OPENGL ES 3.0 学习笔记】延伸阅读:VAO与VBO
笔记·学习·elasticsearch
摇滚侠9 小时前
Spring Boot3零基础教程,Spring Boot 应用打包成 exe 可执行文件,笔记91 笔记92 笔记93
linux·spring boot·笔记
开开心心就好9 小时前
电子报纸离线保存:一键下载多报PDF工具
网络·笔记·macos·pdf·word·音视频·phpstorm
朝新_9 小时前
【SpringMVC】详解用户登录前后端交互流程:AJAX 异步通信与 Session 机制实战
前端·笔记·spring·ajax·交互·javaee
是Yu欸10 小时前
【博资考5】网安2025
网络·人工智能·经验分享·笔记·网络安全·ai·博资考
报错小能手11 小时前
C++笔记(面向对象)RTTI操作符
开发语言·c++·笔记
CodeLongBear11 小时前
计算机网络学习笔记 | 传输层核心知识点总结(DAY03,匠心制作)
笔记·学习·计算机网络
wdfk_prog12 小时前
[Linux]学习笔记系列 -- [kernel][time]tick
linux·笔记·学习
峰顶听歌的鲸鱼13 小时前
9.OpenStack管理(三)
运维·笔记·分布式·openstack·学习方法
立志成为大牛的小牛13 小时前
数据结构——三十七、关键路径(王道408)
数据结构·笔记·程序人生·考研·算法