搜索
查看
编辑修改
首页
UNITY
NODEJS
PYTHON
AI
GIT
PHP
GO
CEF3
JAVA
HTML
CSS
搜索
Gausst松鼠会
这个屌丝很懒,什么也没留下!
关注作者
热门标签
jquery
HTML
CSS
PHP
ASP
PYTHON
GO
AI
C
C++
C#
PHOTOSHOP
UNITY
iOS
android
vue
xml
爬虫
SEO
LINUX
WINDOWS
JAVA
MFC
CEF3
CAD
NODEJS
GIT
Pyppeteer
article
热门文章
1
离线存储网页服务器无响应,网页保存应注意的问题
2
大数据分析培训课程python时间序列预测SARIMAX模型教程
3
【算法】动态规划法_如何从动态规划算法所生成的表中
4
在安卓手机上安装Ubuntu详细教程(无需root)_安卓无root装ubuntu
5
最新互联网大厂职位薪资,快来对号入座吧_大厂架构师年薪结构
6
Do not mutate vuex store state outside mutation handlers.
7
pmp公式整理一览_pmp 静态回收期 动态回收期
8
load a PyTorch model from a TF 2.0 checkpoint, please set from_tf=True
9
<el-tabs>Tabs 标签页增加标签页按钮样式优化_el-tabs before-leave
10
Macbook M1版安装安卓模拟器_mac m1 安卓模拟器
当前位置:
article
> 正文
【C 数据结构】树
作者:Gausst松鼠会 | 2024-04-30 19:27:30
赞
踩
【C 数据结构】树
文章目录
【 1. 基本原理 】
1.1 子树、空树
1.2 有序数、无序树
1.3 森林
【 2. 结点 】
【 3. 度、层次、深度 】
【 1. 基本原理 】
树结构是一种
非线性存储结构
,存储的是具有
一对多
关系的数据元素的集合。
一对多
如下图中的左图所示,对于数据 A 来说,和数据 B、C、D 有关系;对于数据 B 来说,和 E、F 有关系。这就是“一对多”的关系。
将具有“一对多”关系的集合中的数据元素按照上面右图的形式进行存储,整个存储形状在逻辑结构上看,类似于实际生活中倒着的树(左图倒过来),所以称这种存储结构为
树型存储结构
。
树的广义表 表示法
上图用广义表可以表示为:
(A , ( B ( E ( K , L ) , F ) , C ( G ) , D ( H ( M ) , I , J ) ) )
1.1 子树、空树
子树
:上图中,整棵树的根结点为结点 A,而如果单看结点 B、E、F、K、L 组成的部分来说,也是棵树,而且节点 B 为这棵树的根结点。所以称 B、E、F、K、L 这几个结点组成的树为整棵树的子树;同样,结点 E、K、L 构成的也是一棵子树,根结点为 E。
单个结点也是一棵树,根结点就是它本身
。上图中的结点 K、L、F 等都是树,且都是整棵树的子树。
知道了子树的概念后,树可以这样定义:
树是由根结点和若干棵子树构成的
。
在树结构中,
对于具有同一个根结点的各个子树,相互之间不能有交集
。
例如上图中,除了根结点 A,其余元素又各自构成了三个子树,根结点分别为 B、C、D,这三个子树相互之间没有相同的结点。如果有,就破坏了树的结构,不能算做是一棵树。
空树
:如果集合本身为空,那么构成的树就被称为空树。
空树中没有结点
。
1.2 有序数、无序树
如果树中结点的子树从左到右看,谁在左边,谁在右边,是有规定的,这棵树称为
有序树
;反之称为
无序树
。
在有序树中,一个结点最左边的子树称为
第一个孩子
,最右边的称为
最后一个孩子
。
例如上图中,如果其本身是一棵有序树,则以结点 B 为根结点的子树为整棵树的第一个孩子,以结点 D 为根结点的子树为整棵树的最后一个孩子。
1.3 森林
由 m(m >= 0)个互不相交的树组成的集合被称为
森林
。例如上图中,分别以 B、C、D 为根结点的三棵子树就可以称为森林。
前面讲到,树可以理解为是由根结点和若干子树构成的,而这若干子树本身是一个森林,所以,
树还可以理解为是由根结点和森林组成的
。用一个式子表示为:
Tree =(root,F)
,其中,root 表示树的根结点,F 表示由 m(m >= 0)棵树组成的森林。
除了上图表示树的方法外,还有其他表示方法:
【 2. 结点 】
结点
:使用树结构存储的每一个数据元素都被称为结点。例如,上图中的数据元素 A 就是一个结点;
父结点(双亲结点)
、
子结点
、
兄弟结点
:
对于上图中的结点 A、B、C、D 来说,A 是 B、C、D 结点的父结点(也称为“双亲结点”);B、C、D 都是 A 结点的子结点(也称“孩子结点”);
对于 B、C、D 来说,它们都有相同的父结点,所以它们互为兄弟结点。
树根结点(根结点)
:每一个非空树都有且只有一个被称为根的结点。上图中的结点 A 就是整棵树的根结点。
树根的判断依据为:
如果一个结点没有父结点,那么这个结点就是整棵树的根结点
。
叶子结点
:如果结点没有任何子结点,那么此结点称为叶子结点(叶结点)。例如上图中,结点 K、L、F、G、M、I、J 都是这棵树的叶子结点。
【 3. 度、层次、深度 】
对于一个结点,
拥有的子树的数量
(结点有多少分支)称为结点的
度(Degree)
。例如上图中,根结点 A 下分出了 3 个子树,所以,结点 A 的度为 3。
一棵树的度
是树内各结点的度的最大值。例如上图中,各个结点的度的最大值为 3,所以,整棵树的度的值是 3。
结点的层次
:从一棵树的树根开始,树根所在层为第一层,根的孩子结点所在的层为第二层,依次类推。例如上图中,A 结点在第一层,B、C、D 为第二层,E、F、G、H、I、J 在第三层,K、L、M 在第四层。
一棵树的
深度(高度)
是树中结点所在的最大的层次。例如上图中树的深度为 4。
如果两个结点的父结点虽不相同,但是它们的父结点处在同一层次上,那么这两个结点互为
堂兄弟
。例如上图中,结点 G 和 E、F、H、I、J 的父结点都在第二层,所以之间为堂兄弟的关系。
声明:
本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:
https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/514814
推荐阅读
article
【
数据结构
】
哈希
表
的
创建、
查找
(C语言实现)_再编写
一个
函数
,
实现
哈希
表
的
造
表
和
查找
操作。...
本次
的
实验要求弄清楚最关键
的
两个模块,即插入和
查找
,首先要有
哈希
函数
生成映射地址、有
哈希
表
保存元素,然后要有自己设定
的
解...
赞
踩
article
【
数据结构
】
插值
排序...
插值
排序(Interpolation Search)是一种用于在有序数组中查找特定元素的搜索算法。它是二分查找算法的改进...
赞
踩
article
【
数据结构
】模拟
实现
顺序
表
...
ArrayList是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般是用数组完成的。ArrayList底层是...
赞
踩
article
【C语言
数据结构
】
线性
表
-
顺序
表
的实现_c语言构建
线性
顺序
表
...
顺序
表
是用一段物理地址连续的存储单元依次存储数据元素的
线性
结构,一般情况下采用数组存储,并在数组上完成数据的增、删、查、...
赞
踩
article
<
数据结构
> (C语言
实现
)
动态
顺序
表
...
1.线性
表
线性
表
是n个具有相同特性的数据元素的有限序列。常见的线性
表
:
顺序
表
、链
表
、栈、队列、字符串......线性
表
在...
赞
踩
article
【
数据结构
】
时间
复杂度
的
例题
...
【
数据结构
】
时间
复杂度
的
例题
...
赞
踩
article
【
数据结构
】
二叉树
(定义、性质、
存储
、
遍历
、
构造
)解析+完整代码...
定义1.每个结点至多有两棵子树;2.左右子树不能颠倒(
二叉树
是有序树)。特殊
二叉树
1.满
二叉树
一棵高度为h,且含有2h−...
赞
踩
article
C语言【
数据
结构
】
顺序
表
(动态开辟)实现_
c
语言
的
结构
体 开辟空间...
前言:这是
数据
结构
的
开始,
顺序
表
。现在已经开始学
数据
结构
了,学
数据
结构
最重要
的
3点是①善于画图,多画图思考②一定要细心③...
赞
踩
article
【
数据结构
】图的应用(
最小
生成
树、
拓扑
排序
、
最短
路径等)...
本文章介绍
数据结构
中的图的应用,包括
最小
生成
树的Prim算法和Kruskal算法,
拓扑
排序
和
最短
路径,且还包含408习题...
赞
踩
article
数据结构
(
并
查集
,
ST
表)...
【代码】
数据结构
(
并
查集
,
ST
表)
数据结构
(
并
查集
,
ST
表)
并
...
赞
踩
article
数据结构
:
树
的
分类及在
数据库
索引
中
的
运用
...
树
数据库
索引
b
树
b+
树
数据结构
:
树
的
分类及在
数据库
索引
中
的
运用
...
赞
踩
article
数据结构
-图
搜索算法
详解...
图
搜索算法
是
数据结构
和算法学科中的一个重要领域,它们用于在图中搜索顶点(节点)和边(连接节点的线)。图可以是有向的(边有...
赞
踩
article
数据结构
––
复杂度
...
是一个数学表达式,是对一个算法在运行过程中临时占用额外存储空间大小的量度空间
复杂度
不是程序占用了多少bytes的空间,因...
赞
踩
article
数据结构
---
线性
表
(
顺序
表
)附代码...
假定数组有10个空间,已经使用了5个,向数组中插入数据步骤: 求数组的长度,求数组的有效数据个数,向下标为数据有效个数的...
赞
踩
article
【
C
/
C
++
数据结构
线性表】深入
理解
与
实现
栈
:从基础到
应用
的全面探索...
栈
(Stack)是一种特殊的线性
数据结构
,它只允许在一端进行插入和删除操作。这一端通常被称为“
栈
顶”(Top),而另一端...
赞
踩
article
数据结构
––
串
...
由一个或多个称为空格的特殊字符组成的
串
(长度是空格字符的个数):子
串
的定位运算,是一种子
串
在主
串
中第一次出现的第一个字符...
赞
踩
article
《
数据结构
》之八
大
排序
_
从小到
大
排序
是
大
根堆
还
是
小
根堆
...
八
大
排序
---结合基本思想,代码,图解,重点分析,进行详细讲解!!_
从小到
大
排序
是
大
根堆
还
是
小
根堆
从小到
大
排序
是
大
根堆
还...
赞
踩
article
数据结构
:
排序
-
插入
排序
(
插入
排序
and
希尔
排序
) ,
选择
排序
(
选择
排序
and
堆
排序
) , 交换...
数据结构
:
排序
-
插入
排序
(
插入
排序
and
希尔
排序
) ,
选择
排序
(
选择
排序
and
堆
排序
) , 交换
排序
(
冒泡
排序
and
...
赞
踩
article
Java【
数据结构
】
二分
查找
_
java
二分
查找
...
right=arr.length,作为一个边界存在,left可能为我们的
查找
目标,但是right一定不是我们要找到的目标...
赞
踩
article
数据结构
-----
二叉
排序树...
今天我们继续学习新的知识点----排序
二叉
树,在此之前我们学习了相关的排序算法,给你一个数组,然后对这个数组进行排序。那...
赞
踩
相关标签
数据结构
c语言
散列表
算法
java
ArrayList
顺序表
链表
c#
开发语言
c++
b树
笔记
学习
蓝桥杯
图论
考研