【数据结构】 树、二叉树、完全二叉树,先序遍历、中序遍历、后序遍历

树是一种非线性的数据结构

一棵树由n(n>=0)个元素组成,当n为0时,称为空树

树的定义

1.每个元素都可以称为节点

2.非空树中,有一个特定的点,称为根节点或树根

3.每个节点下方连接的节点称为后代节点

没有子树的节点,称为叶子节点

一个节点子树的个数,称为这个结点的度,叶子节点的度为0

树种各结点度的最大值,称为数的度

树中所有节点层次的最大值称为树的深度

二叉树:所有节点的度都不大与2的树

二叉树有5种形态:

二叉树的特性:

  1. 在二叉树的第i层上最多有2i-1个结点(i ≥ 1)
  1. 深度为k的二叉树的总结点个数最多为2k-1个(k ≥ 1)
  1. 满二叉树的定义:一棵深度为k且有2k-1个结点的二叉树称为满二叉树。

完全二叉树:二叉树中除去最后一层结点为满二叉树,且最后一层的结点依次从左到右分布。

二叉树的遍历:

对于二叉树而言,是由三个基本单元组成:根结点、左子树和右子树。因此如果能遍历这三部分,就能遍历整个二叉树

三种二叉树遍历方式

  1. 先序遍历( 根 -> 左 -> 右 )
  2. 中序遍历( 左 -> 根 -> 右 )
  3. 后序遍历( 左 -> 右 -> 根 )
  4. 层序遍历

例如下面这个表:

先序遍历为:e a c b d g f

中序遍历为:a b c d e f g

后序遍历为:b d c a f g e

层序遍历为:e a g c f b d

先序简单方法:在每个节点左边打点,连一根线:

中序简单方法,在每个节点下面打一个点,连一根线:

后序简单方法:在每个节点右边打一个点,连一根线:

前序遍历序列和中序遍历序列相同的二叉树:只有根结点的二叉树或非叶子结点只有右子树的二叉树

序列构造二叉树:

  1. 先序:A B D C E F G
  2. 中序:D B A E G C F

推算二叉树:

相关推荐
小O的算法实验室2 小时前
2024年AST,基于费马点分组粒子群算法的复合型无人机统一路径规划
算法·无人机
AllData公司负责人3 小时前
大模型赋能AllData数据中台,系列升级|通过联合智谱大模型与BiSheng开源项目,建设企业大模型应用开发平台,支持知识库向量检索!
大数据·数据结构·数据库·算法·大模型·向量数据库·智谱ai
一个王同学3 小时前
从零到一 | CV转多模态大模型 | week12 | 整理 MiniLLaVA 工程与文档
人工智能·深度学习·算法·机器学习·计算机视觉
这料鬼有毒3 小时前
二刷hot100-78.子集
算法·leetcode·职场和发展
ZHW_AI课题组3 小时前
使用DBSCAN算法对纽约市 Airbnb 房源数据集进行聚类分析
算法
蓦然回首却已人去楼空4 小时前
【分词:中文分词】BPE字节级分词算法实现汉字表达!
java·算法·中文分词
3DVisionary4 小时前
aero-engine-blade-thermal-fatigue-dic-inspection
人工智能·算法·机器学习·航空发动机·高温dic·涡轮叶片·热疲劳
Kurisu5754 小时前
深度拆解:从二进制切片到并发控制,大文件断点续传的底层工程设计
算法