树的知识概括锦囊(一)

news2024/11/17 22:39:48

作者:爱塔居

专栏:数据结构

作者简介:大三学生,希望跟大家一起进步!

文章目录

目录

文章目录

一、树形结构

二、树的基础知识

三、二叉树

3.1 概念

3.2 特殊的二叉树

​编辑

 3.3 二叉树的性质

四、习题挑战


一、树形结构

树是一种非线性的数据结构,它是由n(n>=0)个有限结点组成一个具有层次关系的集合,把它叫做树是因为它是根朝上,叶子朝下的。

以下这个图就是二叉树:

树有以下特点:

🎈有一个特殊的结点,称为根结点,根结点没有前驱结点

🎗除根结点外,其余结点被分为M(M>0)个互不相交的集合T^{_{1}}T^{_{2}}、……、T_{m},其中每一个集合T(1<=i<=m)又是一棵与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继。

🎀树是递归定义的。

🍟树形结构中,子树之间不能有交集。而且除了根结点,每个结点有且仅有一个父结点

这两种都不是二叉树:

 

🧁一棵N个结点的树有N-1条边

二、树的基础知识

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

树的度:一棵树中所有结点度的最大值称为树的度;如上图:树的度为6

叶子结点或终端结点:度为0的结点称为叶子结点;如上图:B、C、H、I、P、Q、K、L、M、N是叶子结点。

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

孩子结点或子结点:一个结点含有的子树的根结点称为该结点的子节点:B是A的孩子结点

根结点:一个树,没有双亲结点的结点;就如图中的A

结点的层次:从根开始定义,根为第一层,根的子节点为第2层,以此类推。

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

三、二叉树

3.1 概念

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

1.或者为空

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

二叉树不存在度大于2的结点且二叉树的子树有左右之分,次序不能颠倒,所以二叉树是有序树。

3.2 特殊的二叉树

 满二叉树在外观上是一个三角形的结构,比较好认。而且如果一棵二叉树的层数为K,且结点总数为2^{^{k}}-1,则它就是满二叉树。我们还能得出第K层的结点数为2^{k-1}.

满二叉树

 

 如果二叉树中除去最后一层节点为满二叉树,且最后一层的结点依次从左到右分布,则此二叉树被称为完全二叉树。满二叉树是一种特殊的完全二叉树。

 3.3 二叉树的性质

1.若规定根结点的层数为1,则一颗非空二叉树的第i层上最多有2^{i-1}(i>0)个结点(也就是当二叉树为完全二叉树的情况)。

2.若规定只有根结点的二叉树的深度为,则深度为K的二叉树的最大结点数是2^{k}-1(k>=0)(当二叉树为满二叉树的情况)。

3.对任何一棵二叉树,如果其叶结点个数为n_{0},度为2的非叶结点个数为n^{_{2}},则有n_{0}=n_{2}+1

推算过程:

设二叉树度为0的结点数为n_{0},度为1的结点数为n_{1},度为2的结点数为n_{2},总结点数设为N。

二叉树只有这三种结点,故N=n_{0}+n_{1}+n_{2}————①;

我们前面提过,结点为N的二叉树,会有N-1条边。

N-1=2\times n_{2}+1\times n_{1}+0\times n_{0},故N=2\times n_{2}+n_{1}+1————②;

①②联合起来:n_{0}+n_{1}+n_{2}=2\times n_{2}+n_{1}+1,简化后n_{0_{}}=n_{2}+1

4.具有n个结点的完全二叉树的深度k为log_{2}^{(n+1)}上取整。

推导过程:

因为深度为k的二叉树的最大结点数为2^{k}-1

2^{k}-1=n \Rightarrow 2^{k}=n+1 \Rightarrow k=log{_{2}}^{n+1}

5. 对于具有n个结点的完全二叉树,如果按照从上至下从左至右的顺序对所有节点从0开始编号,则对于序号为i的结点有:
若i>0,双亲序号:(i-1)/2;i=0,i为根结点编号,无双亲结点
若2i+1<n,左孩子序号:2i+1,否则无左孩子
若2i+2<n,右孩子序号:2i+2,否则无右孩子
 

四、习题挑战

1. 某二叉树共有 399 个结点,其中有 199 个度为 2 的结点,则该二叉树中的叶子结点数为( )
A 不存在这样的二叉树
B 200
C 198
D 199

推导过程:n_{0}=n_{2}+1\Rightarrow n_{0}=200

2.在具有 2n 个结点的完全二叉树中,叶子结点个数为( )
A n
B n+1
C n-1
D n/2

推导过程:

2n>>偶数个结点的情况:

如图,n=5,叶子结点个数为5

正经推算:

2n=n_{0}+n_{1}+n_{2}

偶数结点的情况:n_{1}=1

n_{0}=n_{2}+1

2n=n_{0}+1+n_{0}-1=2\times n_{0}\Rightarrow n=n_{0}

 

3.一个具有767个节点的完全二叉树,其叶子节点个数为()
A 383
B 384
C 385
D 386
 

推导过程:

奇数个结点:

n_{1}=0

故 n_{0}+n_{2}=767

又因为n_{0}=n_{2}+1

2\times n_{0}-1=767\Rightarrow 2\times n_{0}=768\Rightarrow n_{0}=384

4.一棵完全二叉树的节点数为531个,那么这棵树的高度为( )
A 11
B 10
C 8
D 12

推导过程:具有n个结点的完全二叉树的深度k为log_{2}^{(n+1)}上取整。

 k=log_{2}^{532}

2^{9}=512<532 2^{10}=1024>532

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

手把手教你学51单片机-如何学习单片机

大多数大学生之所以最后变的平庸,不是因为脑子多么笨,也不是全怪自己贪玩不上进,只是没有一个好的领路人,许多学校可能挂着导师的名头,但是多数是挂羊头卖狗肉或者是干脆不管。最后等大学生毕业之后,那些所谓的老师就会说学生很差或者学习很差,反正就是跟自己没啥关系。…

OSPF综合实验(华为)

题目&#xff1a; 思路&#xff1a; 首先配置每个区域的路由和环回地址&#xff0c;其次&#xff0c;根据题目要求打通每个网络的连接&#xff0c;区域0用MGRE打通网络&#xff0c;区域4需要重发布&#xff0c;其次再考虑优化的问题。ip地址的规划是为了更好的路由汇总&#x…

《 Unity Shader 入门精要》第5章 开始 Unity Shader 学习之旅

第5章 开始 Unity Shader 学习之旅 5.2 一个最简单的顶点/片元着色器 顶点/片元着色器的基本结构 // Upgrade NOTE: replaced mul(UNITY_MATRIX_MVP,*) with UnityObjectToClipPos(*)// 定义 shader 的名字 Shader "Chapter 5/Simple Shader" {SubShader{Pass {//…

自动驾驶控制算法之车辆横向控制(project)

本文为深蓝学院-自动驾驶控制与规划-第三章作业 目录 1 projection introduction 2 思路提示 2.1 ComputeControlCmd 2.2 ComputeLateralErrors 3 Corer Case 3.1 Low speed operation 3.2 Extra damping on heading 3.3 Steer into constant radius curve 4 ROSLGSV…

FFmpeg-4.2.4的filter: drawbox源码分析

1. vf_drawbox.c功能 有两个功能 ,添加方框,和添加网格; 1.1 添加方框效果 1.2 添加网格效果

c++数据结构-树(详细总结附代码,一看就懂)

树的定义一棵树是由n&#xff08;n>0&#xff09;个元素组成的有限集合&#xff0c;其中&#xff1a;&#xff08;1&#xff09;每个元素称为结点&#xff08;node&#xff09;&#xff08;2&#xff09;有一个特定的结点&#xff0c;称为根结点或树根&#xff08;root&…

上海亚商投顾:双创指数低开高走,数字经济继续活跃

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。市场情绪三大指数今日低开高走&#xff0c;创业板指午后涨超1%&#xff0c;科创50指数涨超1.6%。数字经济概念继续爆发&#…

算法基础(一):时间复杂度和空间复杂度

算法基础&#xff08;一&#xff09;&#xff1a;时间复杂度和空间复杂度时间复杂度 O(1)O(1)O(1) O(N)O(N)O(N) O(logN)O(log N)O(logN) O(MN)O(MN)O(MN) O(NlogN)O(Nlog N)O(NlogN)、O(MlogN)O(Mlog N)O(MlogN) O(N2)O(N^2)O(N2)空间复杂度一些算法基础知识点和leetcode题解&…

【网络通信】【电信运营商实战工程师】思科设备篇-思科设备企业网实战

电信运营商实战工程师系列文章. 思科设备篇-思科设备企业网实战. 文章目录1. 思科设备基本开局配置2. ARP协议、交换机工作原理及广播风暴问题3. 思科设备 VLAN 及单臂路由实战4. 思科三层交换机实现 VLAN 间路由实战5. 思科设备静态默认及浮动路由实战6. 思科设备NAT实战全集1…

YOLO_V8训练自己的数据集

YOLO_V8在2023年开年横空出世&#xff0c;在春节前还得卷一下。由于YOLO_V8和YOLO_V5是同一个作者&#xff0c;所以很多操作都是一样的&#xff0c;下面主要描述一下如何用自己的数据集进行训练和测试&#xff08;非命令行的方式&#xff09;。1、训练数据和模型的目录结构这里…

设计模式学习(九):Abstract Factory抽象工厂模式

目录 一、什么是Abstract Factory模式 二、Abstract Factory示例代码 2.1 类之间的关系 2.2 抽象的零件:ltem类 2.3 抽象的零件:Link类 2.4 抽象的零件:Tray类 2.5 抽象的产品: Page类 2.6 抽象的工厂:Factory类 2.7 使用工厂将零件组装称为产品:Main类 2.8 具体的工厂…

linux三剑客之AWK

目录 AWK是什么 AWK基本结构 a.txt的文本实例 AWK内置变量 a.txt的文本实例 AWK自定义变量 a.txt的文本实例 AWK内置函数 a.txt的文本实例 awk高级输出 a.txt的文本实例 排序输出 a.txt的文本实例 条件选择输出 a.txt的文本实例 控制语句 a.txt的文本实例 AWK是什…

Java SE 继承和多态

继承和多态 1. 继承 1.1 为什么需要继承 Java中使用类对现实世界中实体来进行描述&#xff0c;类经过实例化之后的产物对象&#xff0c;则可以用来表示现实中的实体&#xff0c;但是 现实世界错综复杂&#xff0c;事物之间可能会存在一些关联&#xff0c;那在设计程序是就需…

Elasticsearch7.8.0版本高级查询—— 指定查询字段查询文档

目录一、初始化文档数据二、指定查询字段查询文档2.1、概述2.2、示例一、初始化文档数据 在 Postman 中&#xff0c;向 ES 服务器发 POST 请求 &#xff1a;http://localhost:9200/user/_doc/1&#xff0c;请求体内容为&#xff1a; {"name":"张三","…

Git知识学习

主要内容&#xff1a;熟练掌握Git、GitHub、GitLab、Gitee码云的使用 文章目录1.Git概述1.1版本控制1.2版本控制工具1.3Git和代码托管中心2.Git常用命令2.1设置用户签名2.2初始化本地库2.3查看本地库状态2.3.1首次查看2.3.2新增文件2.3.3再次查看2.4添加暂存区2.4.1将工作区文件…

! LaTeX Error: File xxx.sty not found-统一解决办法

在使用一些模板时常见这个错&#xff0c;其实就是缺宏包&#xff01;解决方案如下&#xff01; 第一步&#xff1a;在网站 https://ctan.org/pkg 找到你缺失的宏包&#xff0c;下载zip文件。 第二步&#xff1a;将解压后的文件夹复制到安装路径下&#xff1a; 如&#xff…

aws ecs 理解任务和容器的资源分配

参考资料 如何在 Amazon ECS 中为任务分配内存&#xff1f; 关于 Amazon ECS 中的 CPU 分配&#xff0c;我需要了解哪些信息&#xff1f; Amazon ECS CloudWatch 指标 任务定义参数 在ecs中可以指定资源的分配逻辑&#xff0c;其实就是cpu和内存分配。 下面这张图对ecs任…

搜索本地文件

李国春 处理大量的数据集时将文件整理到一起也是一个重要的工作。本文介绍一个将本地计算机目标文件的绝对路径汇集到一个文本文件的中的脚本。以方便后续批量处理这些文件。 启动RSD&#xff0c;在脚本编辑窗口输入图1中的代码。点击工具条上的小三角开始运行&#xff0c;提…

计网必会:电子邮件、SMTP协议

文章目录SMTP概念SMTP的操作过程——发送邮件-接收邮件细品&#xff1a;发送邮件与HTTP的对比邮件报文格式和MIME邮件访问协议SMTP概念 SMTP是电子邮件中的主要协议&#xff0c;它能使用TCP可靠数据传输服务&#xff0c;从发送方的服务器向接收方发送邮件&#xff0c; SMTP&am…

第四章必备前端基础知识-第二节1:CSS概述和选择器

文章目录一&#xff1a;CSS概述&#xff08;1&#xff09;概述&#xff08;2&#xff09;语法规范&#xff08;3&#xff09;CSS引入方式二&#xff1a;选择器&#xff08;1&#xff09;基础选择器①&#xff1a;标签选择器②&#xff1a;类选择器③&#xff1a;id选择器④&…