当前位置: 首页 > news >正文

树的初阶相关知识(上)

一.树概念及结构

1.1 树的概念

树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合。把它叫做树是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的

有一个特殊的结点,称为根结点,根节点没有前驱结点除根节点外,其余结点被分成M(M>0)个互不相交的集合T1T2……Tm,其中每一个集合Ti(1<= i<= m)又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继因此,树是递归定义的。

前驱的意思就是该节点是否有上级节点,后继的意思就是该节点下面是否有节点

注意:树形结构中,子树之间不能有交集,否则就不是树形结构

1.2 树的相关概念

节点的度:一个节点含有的子树的个数称为该节点的度;如上图:A的为6

叶节点或终端节点:度为0的节点称为叶节点;如上图:B、C、H、I...等节点为叶节点

非终端节点或分支节点:度不为0的节点;如上图:D、E、F、G...等节点为分支节点

双亲节点或父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点;如上图:A是B的父节点

孩子节点或子节点:一个节点含有的子树的根节点称为该节点的子节点;如上图:B是A的孩子节点

兄弟节点:具有相同父节点的节点互称为兄弟节点;如上图:B、C是兄弟节点

树的度:一棵树中,最大的节点的度称为树的度;如上图:树的度为6

节点的层次:从根开始定义起,根为第1层,根的子节点为第2层,以此类推;

树的高度或深度:树中节点的最大层次;如上图:树的高度为4

节点的祖先:从根到该节点所经分支上的所有节点;如上图:A是所有节点的祖先

子孙:以某节点为根的子树中任一节点都称为该节点的子孙。如上图:所有节点都是A的子孙

森林:由m(m>0)棵互不相交的树的集合称为森林;

重点记忆的:叶节点、父节点、子节点、树的读和树的高度

1.3 树的表示

树结构相对线性表就比较复杂了,要存储表示起来就比较麻烦了,既然保存值域,也要保存结点和结点之间的关系,实际中树有很多种表示方式如:双亲表示法,孩子表示法、孩子双亲表示法以及孩子兄弟表示法等。我们这里就简单的了解其中最常用的孩子兄弟表示法

typedef int DataType; struct Node { Node* _firstChild; // 第一个孩子节点 Node* _pNextBrother; // 下一个兄弟节点 DataType _data; // 数据域 };

而这个在实际中的应用:文件系统的结构


二.二叉树概念及结构

2.1 二叉树的概念

一棵二叉树是结点的一个有限集合,该集合:

1. 为空或者只有一个根节点

2. 由一个根节点加上两棵别称为左子树和右子树的二叉树组成

从上图可以看出:

1. 二叉树不存在度大于2的结点(即一个节点最多只有两个分支)

2. 二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树

注意:对于任意的二叉树都是由以下几种情况复合而成的

2.2 特殊的二叉树

1.满二叉树:一个二叉树,如果每一个层的结点数都达到最大值,则这个二叉树就是满二叉树。也就是说,如果一个二叉树的层数为K,且结点总数是2ᵏ-1,则它就是满二叉树。

2.完全二叉树:完全二叉树是效率很高的数据结构,完全二叉树是由满二叉树而引出来的。对于深度为K的,有n个结点的二叉树,当且仅当其每一个结点都与深度为K的满二叉树中编号从1至n的结点一一对应时称之为完全二叉树。 要注意的是满二叉树是一种特殊的完全二叉树。

2.3 二叉树的性质

1.i>0i位置节点的双亲序号:(i-1)/2;i=0,i为根节点编号,无双亲节点

2.2i+1<n,左孩子序号:2i+12i+1>=n否则无左孩子

3.2i+2<n,右孩子序号:2i+22i+2>=n否则无右孩子

1. 某二叉树共有 399 个结点,其中有 199 个度为 2 的结点,则该二叉树中的叶子结点数为( ) A 不存在这样的二叉树 B 200 C 198 D 199 2.下列数据结构中,不适合采用顺序存储结构的是( ) A 非完全二叉树 B 堆 C 队列 D 栈 3.在具有 2n 个结点的完全二叉树中,叶子结点个数为( ) A n B n+1 C n-1 D n/2 4.一棵完全二叉树的节点数位为531个,那么这棵树的高度为( ) A 11 B 10 C 8 D 12 5.一个具有767个节点的完全二叉树,其叶子节点个数为() A 383 B 384 C 385 D 386 答案: 1.B 2.A 3.A 4.B 5.B

这些答案都是上面二叉树的性质,就不和大家讲解了!

2.4 二叉树的存储结构

二叉树一般可以使用两种结构存储,一种顺序结构,一种链式结构。

1.顺序存储

顺序结构存储就是使用数组来存储,一般使用数组只适合表示完全二叉树,因为不是完全二叉树会有空间的浪费。而现实中使用中只有堆才会使用数组来存储,关于堆我们后面的章节会专门讲解。二叉树顺序存储在物理上是一个数组,在逻辑上是一颗二叉树。

2.链式存储

二叉树的链式存储结构是指,用链表来表示一棵二叉树,即用链来指示元素的逻辑关系。 通常的方法是链表中每个结点由三个域组成,数据域和左右指针域,左右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址 。链式结构又分为二叉链和三叉链,当前我们学习中一般都是二叉链,后面课程学到高阶数据结构如红黑树等会用到三叉链。

typedef int BinaryTreeNode; struct BinaryTreeNode { BinaryTreeNode* _pLeft; // 指向当前节点左孩子 BinaryTreeNode* _pRight; // 指向当前节点右孩子 BTDataType _data; // 当前节点值域 }; struct BinaryTreeNodeWithParent { BinaryTreeNodeWithParent* _pParent; // 指向当前节点的双亲 BinaryTreeNodeWithParent* _pLeft; // 指向当前节点左孩子 BinaryTreeNodeWithParent* _pRight; // 指向当前节点右孩子 BTDataType _data; // 当前节点值域 };

三.二叉树的顺序结构及实现

3.1二叉树的顺序结构

普通的二叉树是不适合用数组来存储的,因为可能会存在大量的空间浪费。而完全二叉树更适合使用顺序结构存储。现实中我们通常把堆(一种二叉树)使用顺序结构的数组来存储,需要注意的是这里的堆和操作系统虚拟进程地址空间中的堆是两回事,一个是数据结构,一个是操作系统中管理内存的一块区域分段。

3.2堆的概念及结构

堆的性质:

  1. 堆中某个节点的值总是不大于或不小于其父节点的值;
  2. 堆总是一棵完全二叉树

一些相关堆的选择题

1.下列关键字序列为堆的是:() A 100,60,70,50,32,65 B 60,70,65,50,32,100 C 65,100,70,32,50,60 D 70,65,100,32,50,60 E 32,50,100,70,65,60 F 50,100,70,65,60,32 2.已知小根堆为8,15,10,21,34,16,12,删除关键字 8 之后需重建堆,在此过程中 关键字之间的比较次数是()。 A 1 B 2 C 3 D 4 3.一组记录排序码为(5 11 7 2 3 17),则利用堆排序方法建立的初始堆为 A(11 5 7 2 3 17) B(11 5 7 2 17 3) C(17 11 7 2 3 5) D(17 11 7 5 3 2) E(17 7 11 3 5 2) F(17 7 11 3 2 5) 4.最小堆[0,3,2,5,7,4,6,8],在删除堆顶元素0之后,其结果是() A[3,2,5,7,4,6,8] B[2,3,5,7,4,6,8] C[2,3,4,5,7,8,6] D[2,3,4,5,6,7,8]

或许大家不会做,没关系因为我还没有讲堆的具体实现,如果不会做可以留到我下一章,当然如果大家会做也可以先做,我在下一章会给出详解和答案。

关于本章内容重点是:了解树的概念,至于树的表示我们只需要了解一下,毕竟我们后面的重心是关于二叉树的性质,关于树的理论知识是不难的,难点在于与树常见搭配的递归!

http://www.jsqmd.com/news/88236/

相关文章:

  • 基于springboot和vue的大学生课程排课管理系统设计_2ux3bmwb(java毕业设计项目源码)
  • 基于springboot和vue的扫码解锁共享单车管理系统设计与实现_0455qudf(java毕业设计项目源码)
  • 2025年成都靠谱的抖音代运营品牌哪家好,网站建设/网络公关/网络推广/新闻营销/抖音推广/抖音代运营品牌推荐排行榜 - 品牌推荐师
  • 云数据库服务(如AWS RDS)的优势和考虑因素?
  • 使用NeMo框架微调Llama 3.1 8B Instruct推理模型
  • [论文阅读] AI + 软件工程 | 突破混合与跨语言壁垒!UniCoR让代码检索更智能高效
  • NVIDIA NeMo训练一个具备推理能力的LLM
  • 磁链观测器实战:从仿真到代码的闭环之旅
  • 墨迹蘑菇休闲小游戏Linux演示
  • WHERE和HAVING子句的使用场景有何不同?
  • JVM 之 内存溢出实战【OOM? SOF? 哪些区域会溢出?堆、虚拟机栈、元空间、直接内存溢出时各自的特点?以及什么情况会导致他们溢出?并模拟溢出】
  • 混沌这玩意儿在优化算法里真是万金油。今天咱们拿灰狼算法开刀,手把手给它装10种不同的混沌引擎。先上硬货——代码仓库里直接塞个混沌生成器
  • 基于TMS320F28335芯片的BUCK双闭环PI DSP代码
  • 质量管理QMS软件系统:全模块构建卓越质量生态,数据驱动价值升级——全星质量管理QMS软件系统应用解析
  • AVL树的四种旋转操作用于在插入或删除节点导致二叉树失去平衡
  • vue基于Spring Boot框架学生健康饮食与运动管理系统_c3g9i4f9
  • *SPOOLing 技术(假脱机技术)** - 全称:Simultaneous Peripheral Operations On-Line(外部设备同时联机操作)
  • 超声相控阵全聚焦算法 Comsol超声全矩阵仿真模型(仿真模型可以获得全矩阵数据)
  • 17、Debian系统管理基础与实用工具介绍
  • 量子软件测试:我们准备好了吗?
  • 2026年最新教程!手把手教你用Python画一颗圣诞树(附源码)无需部署可直接运行!
  • 沉浸式LED显示屏LED电子屏多少钱
  • 在虚拟内存管理中,页面置换算法用于决定当物理内存满时,应将哪个页面换出
  • AI使用总结
  • 18、Debian 系统用户与认证管理全解析
  • 存储管理技术主要分为页式、段式和段页式三种,它们在内存空间的划分方式
  • 19、Debian 系统初始化与自动进程管理全解析
  • 【设计模式|第四篇】适配器模式:让不兼容的接口协同工作
  • 线程是进程内的独立调度单位,是CPU调度的基本单元
  • 20、Debian系统管理:备份与设备管理全解析