04树 + 堆 + 优先队列 + 图(D1_树(D1_基本介绍))

server/2025/2/1 13:39:40/

目录

一、什么是树?

二、相关术语

根结点

叶子结点

兄弟结点

祖先结点

结点的大小

树的层

结点的深度

结点的高度

树的高度

斜树


一、什么是树?

树是一种类似于链表的数据结构,不过链表的结点是以线性方式简单地指向其后继结点,而树的一

个结点可以指向许多个结点。

树是一种典型的非线性结构。

树结构是表达具有层次特性的图结构的一种方法。

对于树ADT(抽象数据类型),元素的顺序不是考虑的重点。

如果需要用到元素的顺序信息,那么可以使用链表、栈、队列等线性数据结构

二、相关术语

根结点

根节点:根结点是一个没有双亲结点的结点。一棵树中最多有一个根结点(如上图的结点 A 就是根结点)。

边:边表示从双亲结点到孩子结点的链接(如上图中所有的链接)。

叶子结点

叶子节点:没有孩子结点的结点叫作叶子结点(如E、J、K、H和I)。

兄弟结点

兄弟结点:拥有相同双亲结点的所有孩子结点叫作兄弟结点(B、C、D是A的兄弟结点,E、F是B的

兄弟结点

祖先结点

祖先结点:如果存在一条从根结点到结点q的路径,且结点力出现在这条路径上,

那么就可以把结点力叫作结点q的祖先结点,结点q也叫作力的子孙结点。例如,A、C和G是K的祖

先结点。

结点的大小

结点的大小:结点的大小是指子孙的个数,包括其自身。(子树C的大小为3)。

树的层

树的层:位于相同深度的所有结点的集合叫作树的层(B、C和D具有相同的层)。

根结点位于0层。

结点的深度

结点的深度:是指从根结点到该结点的路径长度(G点的深度为2,A-C-G)。

结点的高度

结点的高度:是指从该结点到最深结点的路径长度。树的高度是指从根结点到树中最深结点的路径

长度。

只含有根结点的树的高度为 0。在前面的例子中,B的高度为2(B-F-J)。

树的高度

树的高度:是树中所有结点高度的最大值,树的深度是树中所有结点深度的最大值。

对于同一棵树,其深度和高度是相同的。但是对于各个结点,其深度和高度不一定相同。

斜树

斜树:如果树中除了叶子结点外,其余每一结点只有一个孩子结点,则这种树称作斜树。

对于每个结点仅有一个左孩子结点的树叫作左斜树。类似地,对于每个结点仅有右孩子结点的树叫

作右斜树。


http://www.ppmy.cn/server/164080.html

相关文章

Java小白入门教程:类?方法?变量?

目录 一、类 二、方法 三、变量 四、示例 一、类 类就像是造东西的蓝图或者模具。 在Java中,类定义了对象的结构和行为。 你可以把类想象成一个工厂的生产线,它决定了最终生产的产品(对象)是什么样子的。 public class 类名…

国产之光DeepSeek架构理解与应用分析

目录 初步探索DeepSeek的设计 一、核心架构设计 二、核心原理与优化 三、关键创新点 四、典型应用场景 五、与同类模型的对比优势 六、未来演进方向 从投入行业生产的角度看 一、DeepSeek的核心功能扩展 二、机械电子工程产业中的具体案例 1. 预测性维护(Predictive…

1.文件 标准IO库

1.文件 标准IO库 **1. 标准I/O库概述****2. 文件的概念与类型****3. 标准I/O库的函数分类****4. 缓冲机制****5. 文件操作步骤****6. 文件定位****7. 常见函数详解****8. 练习与作业****9. 其他注意事项****10. 总结** 1. 标准I/O库概述 标准I/O库:由Dennis Ritchi…

昆虫机器人:从仿生设计到未来应用

目录 引言:从科幻到现实的启示仿生昆虫机器人:技术突破与功能解析应用场景:农业与灾后救援的革新技术难点:微型机器人研发的挑战未来趋势:智能化与群体协作的潜力总结:昆虫机器人技术的广阔前景 1. 引言&am…

动态规划每日一练(四)

一、day1——最长数对链 题目链接&#xff1a; 646. 最长数对链 - 力扣&#xff08;LeetCode&#xff09;646. 最长数对链 - 给你一个由 n 个数对组成的数对数组 pairs &#xff0c;其中 pairs[i] [lefti, righti] 且 lefti < righti 。现在&#xff0c;我们定义一种 跟随…

简识JVM中并发垃圾回收器和多线程并行垃圾回收器的区别

在JVM中&#xff0c;多线程并行垃圾回收器和并发垃圾回收器是两种不同类型的垃圾回收机制&#xff0c;它们的主要区别在于垃圾收集线程与用户线程之间的运行关系&#xff0c;以及这种关系对应用程序性能的影响。以下是对这两种垃圾回收器的详细比较&#xff1a; 一、多线程并行…

用 HTML 实现新春烟花的详细笔记

新年的钟声即将敲响&#xff0c;绚丽的烟花在夜空中绽放&#xff0c;将节日氛围拉满。想不想把这美好的一幕搬到你的网页上&#xff0c;下面跟着小编用 HTML 和 JavaScript 打造出专属的新春烟花特效吧&#xff0c;制造属于IT的浪漫吧&#xff01;朋友们 一、准备舞台&#xff…

npm cnpm pnpm npx yarn的区别

npm、cnpm、pnpm、npx、yarn 这几个工具都与 Node.js 项目的包管理和命令执行相关&#xff0c;它们的区别具体如下&#xff1a; 本质与功能定位 npm&#xff1a;是 Node.js 官方的包管理工具&#xff0c;提供了安装、卸载、更新、发布等全方位的包管理功能&#xff0c;还能通…