平衡树-入门

news/2025/3/26 17:45:41/文章来源:https://www.cnblogs.com/oierhjc114514/p/18790369

本文有一只奶龙编写,有借鉴会在其中说明。

平衡树

要了解平衡树是什么,我们需要先了解一个东西:二叉搜索树(也称二叉查找树)。

  • 二叉搜索/查找树(BST)

如果我们有一颗二叉树可以进行查找,那么就可以说明其中的节点一定又有一个能够区分大小的“键值”。我们有节点来存储这些键值。这些节点最好可以按照它们各自的键值来进行排序(按照好坏优劣),这样才可以在这棵树上面进行高效且快速的查找,于是一个名词就这样诞生了:二叉搜索/查找树(Binary Search Tree,俗称 BST)。

我们现在来分析一下 BST 的一些特征,知道这些我们才可以来了解平衡树。

  • BST 的特征

我们可以发现,BST 具有以下特征:

  1. BST 中的每一个节点都只有唯一的键值,且这些键值可以按照好坏优劣来区分它们的大小。

  2. 在 BST 上,以任意一个节点作为一棵子树的根,那么这棵子树一定也是一颗 BST(当然,这是显然的)。任何节点的键值都比它的左边的节点的键值要大一些,自然,任何节点的键值都比它的右边的节点的键值要小一些。可以发现,承载最大的键值的节点没有右节点,因为右节点需要大于根节点。

那我们可以来用图片来理解一下:

比如这就是一颗标准的 BST,其中我们可以发现的是,如果对于特征 2,那么使用中序遍历就可以得到了一个有序的排列(中序遍历:先遍历左子树,然后是根,然后是右子树)。

如图所示,那么我们得到的序列应该是 \([1, 2, 3, 4, 5 , 6]\)

通过虚线可能会更加清楚:

如图所示,我们在图上画了一些虚线,把每一个节点都隔开,这是可以发现,树上的节点正好按照从小到大的顺序被虚线所隔开,刚好形成了一个有序的序列。到后面,有了这些虚线的帮助,我们可以跟好的去理解 Treap 和 Splay 树中“旋转”的操作技术。

既然都是二叉查找树了,那么我们在 BST 查找一个数,查找的次数其实就是这颗二叉搜索的树的深度。我们来举个例子,我们现在需要来查找 \(3\) 这个节点,从根节点开始,沿着 4->2->3 的顺序查找两次就确定了。我们在建立一颗二叉查找树的时候,如果每一层差不多都是满的节点,那么此时的 BST 的层次是最少的,此时,才能最好的展现 BST 的威力。

  • BST 的形态

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/905035.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

安卓工程目录结构

根目录 根目录下有多个重要的文件和文件夹,各自承担着不同的功能。.gradle 和 .idea 这两个文件夹属于 IDE(集成开发环境)生成的文件,其中 .gradle 包含 Gradle 构建系统的配置和缓存信息;.idea 则是 IntelliJ IDEA 或者 Android Studio 所产生的项目配置文件。 app 这是安…

LLM大模型:post-train实战 - 使用GRPO微调LLM

deepseek带火了GRPO,更带火了reinforcement learning,让研究人员发现RL能在pre-train的基础上较大提升LLM的逻辑推理能力!当前,互联网高速发展二十多年产生的优质数据已经使用殆尽,所以更大规模的LLM一直难产(GPT-5现在都还没发布,优质token耗尽是核心原因之一)。市面上…

MQ 消息幂等性保证

MQ 消息幂等性保证 1. 什么是幂等性 在程序开发中,是指同一个业务,执行一次或多次对业务状态的影响是一致的。例如:根据 id 删除数据 查询数据在实际业务中,避免不了出现用户连续点击退款、重复点击删除等情况,这种情况下,就需要对多个消息进行处理,避免短时间内多次执行…

3.24 曲线/曲面积分

1 第一类曲线积分 (理解成求曲线的质量) 要把ds(弧微分)转化成dt(参数方程里面的自变量)(积分里面只留下的变量),也可以转化成dx什么的,注意ds转化成dx的公式 2 第一类曲面积分 还是先求投影,比如投影到xoy平面上,就求z=z(x,y) 2.1 普通对称性奇函数为0,偶函数*2 2.…

SmolVLM2: 让视频理解能力触手可及

一句话总结: SmolVLM 现已具备更强的视觉理解能力📺 SmolVLM2 标志着视频理解技术的根本性转变——从依赖海量计算资源的巨型模型,转向可在任何设备运行的轻量级模型。我们的目标很简单: 让视频理解技术从手机到服务器都能轻松部署。 我们同步发布三种规模的模型 (22 亿/5 亿…

React-Native开发鸿蒙NEXT-video

React-Native开发鸿蒙NEXT-video 前几周的开发,基本把一个”只读型“社区开发的差不多了。帖子列表,详情,搜索都迁移实现了,但还差了一点------视频类型帖子的展示。之前开发RN社区中,对于视频的处理用的是react-native-video,这个三方组件也已经实现了鸿蒙化,部分逻辑可…

React-Native开发鸿蒙NEXT-cookie设置

React-Native开发鸿蒙NEXT-cookie设置 应用有个积分商城,做一些积分兑换的业务,就一个基于react-native-webview开发的页面,在页面加载的时候通过js注入来设置cookie带入用户信息。 早先应甲方要求web网站关闭了,现在又要继续运行。于是就把web服务启动了,然后发现应用里积…

第六天

单词 以下是今天需学习的35个单词复习,同时前几天的单词阅读 理解文章大意,记录不认识的单词。今天这个阅读非常应当下的情景。 How to Teach Yourself Anything in Less than Three Months 如何在3个月内学习任何一件事(一) Self-education can be wonderful and frustrat…

React Native开发鸿蒙Next---富文本浏览

React Native开发鸿蒙Next---富文本浏览 最近在继续开发App剩余的社区功能。地铁的社区相对较为特殊,只有公告/政策规章/操作指南等资讯阅读功能,无法进行交互。对于原先的社区RN,除了移植适配鸿蒙,还需要做大量的功能屏蔽等改造。新的社区后台大量采用富文本进行内容编辑,…

17.指针

正如您所知道的,每一个变量都有一个内存位置,每一个内存位置都定义了可使用 & 运算符访问的地址,它表示了在内存中的一个地址。 请看下面的实例,它将输出定义的变量地址:#include <stdio.h>int main(){int var_runoob = 10;int *p; //定义指针变量p = &var…

3.24 学习记录

实现了学习记录APP的登录注册功能

2025西安交大集训Day2:DFS,BFS记忆化搜索,迭代加深搜索,二分搜索

2025西安交大集训Day2:DFS,BFS记忆化搜索,迭代加深搜索,二分搜索