数据结构——二叉树知识点详解!

引言:本篇博客将详细介绍到数据结构中的又一位大将——二叉树。它也是我们目前学到的第一个非线性的数据结构。并且本章将学到的概念居多,希望大家可以理解并牢记。

更多有关C语言和数据结构知识详解可前往个人主页:计信猫

目录

一,树

1,树的概念

2,树的定义

二,二叉树

1,二叉树的概念

2,特殊的二叉树

Ⅰ ,满二叉树

Ⅱ,完全二叉树

3,二叉树的储存

三,结语


一,树

1,树的概念

        是一种非线性的数据结构,它由n(n>=0)个有限节点组成一个具有层次关系的集合。而在形式上就像一个倒挂的树,根在上,叶在下。如下图,就是一棵树:

        想要真正的了解一棵,那我们还应该继续掌握关于的细枝末节的概念知识。 

父节点/双亲节点                                     子节点/孩子节点

节点的度:某节点所含有的子节点的个数。例如A的度就为2

兄弟节点:具有相同父节点的节点。如B,C就为兄弟节点

叶节点/终端节点:子节点为0的节点。如D,E,F,G,H

堂兄弟节点:父节点处于同一层上的节点。

树的度:所包含的节点中的的最大值。例如这棵树的度就为3

树的高度:树的最大层次(深度)。例如这棵树的高度就为3

森林:互不相交的的集合。

        当然,我们也会遇到两棵比较特殊的,如下:

 此时空树高度就为0,只有根节点的树高度就为1。

        想要成为一棵,也需要同时遵守以下规则:

1,子树之间便可以有相连或者相交的情况出现。

2,除了根节点以外,每一个节点有且仅有一个父节点。

2,树的定义

        对于的定义,则存在一个难点,那就是一个节点的子节点的个数不确定性,导致我们不知道该定义多少个指针变量合适。

        但是,我们可以使用一个方法,叫做左孩子右兄弟定义法来完美地解决这个问题。于是我们如下代码定义一个

struct TreeNode
{int val;struct TreeNode* LeftChild;//左孩子struct TreeNode* RightBrother;//右兄弟
};

        所以有了这个方法,我们就可以很轻松地将如下的使用代码进行表示了。

        而在使用此方法时,我们必须确保左孩子一定是每一层最左边的那一个。于是我们便可以使用如下代码来遍历一棵的某一层。

struct TreeNode*cur=parent->LeftChild;//parent表示根节点
while(cur)
{//……cur=cur->RightBrother;
}

二,二叉树

1,二叉树的概念

        二叉树无非本质上就首先是一棵,所以它拥有的全部概念。其次二叉树的特殊之处就是二叉树的度为2,也就是说一个节点子节点数不可以超过2

那么如下,就是一棵二叉树

       

2,特殊的二叉树

Ⅰ ,满二叉树

        满二叉树的定义就是除了叶节点之外,每一个节点都达到含有了两个子节点二叉树。如下图所示:

        倘若满二叉树的高度为H,那么我们便可以计算出它的节点个数:

Ⅱ,完全二叉树

        完全二叉树则要求,前H-1层满二叉树,最后一层的叶节点从左向右连续。如下图所示:

        而所要求的”连续“的意思其实就是从左到右必须叶节点紧挨着叶节点,不可以有空出来的位置。

那我们举出如下反例,便不是完全二叉树:

3,二叉树的储存

        对于二叉树的储存,我们便是将逻辑结构与物理结构进行分离储存。

逻辑结构:树状结构              

物理结构:数组结构

        利用数组储存二叉树数据的好处就是我们可以使用下标找到某个节点的父节点或者子节点。 

通过下标寻找父/子节点

假设父节点的下标为i:左孩子节点的下标为2*i+1右孩子节点下标为2*i+2

假设子节点的下标为j:不管j为奇数或者偶数,其父节点的下标都为(j-2)/2——因为会涉及到int类型取整操作

注意:若为非完全二叉树,则不存在的节点一定要在数组空出来,不然会导致使用下标寻找父子节点的方法失效

三,结语

        这一篇文章也仅仅只是讲到了二叉树的概念而已,接下来我会尽快更新出二叉树数据结构的应用——堆

        相较于我们以前学到的数据结构就更加的复杂难懂了,如果想要看懂,那么将这篇博客所讲到的知识点,尤其是父子节点下标的寻找烂熟于心就是非常重要的了。希望我们可以一起克服我们所遇到的困难,一起加油!

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

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

相关文章

AIGC行业现在适合进入吗

AIGC行业目前正处于快速发展阶段,市场需求正处于爆发期,上大学网(www.sdaxue.com)认为,对于有兴趣的个人或企业而言,现在可能是一个适合进入的时机,以下是具体的分析,供大家参考! 一、AIGC行业前…

网络安全基础知识

目录 1、什么是防火墙?什么是堡垒主机?什么是DMZ? 2、网络安全的本质是什么? 3、计算机网络安全所面临的威胁分为哪几类?从人的角度,威胁网络安全的因素有哪些? 4、网络攻击和防御分别包括那…

zip file is empty

从下找到报错的jar包。展开这个jar包,看下是否正常,正常的是能够展开看到一些文件夹以及里面的类,如下:如果不正常,就删除这个jar包,同时找到这个jar包在本地maven仓库的地址,也删除掉&#xff…

string类实现

目录 string类实现 1.构造函数(三种) 2.c_str()函数 3.operator[] 重载 4.size()函数实现 5.迭代器 6.reserve()函数实现 7.push_back()函数实现 8.append()函数实现 9.operator实现 10.insert() 实现 11.erase()函数实现 12.find()函数实现…

Chrome 浏览器的常用命令包括

Chrome 浏览器的常用命令包括: 1. **新建标签页**:Ctrl T (在 Windows/Linux 下),Command T (在 macOS 下)。 2. **关闭当前标签页**:Ctrl W (在 Windows/Linux 下&…

Java面试八股之Collection和Collections的区别

Java中Collection和Collections的区别 Collection 是一个接口,位于 java.util 包中,它是 Java 集合框架的顶层接口之一,代表了一组对象的集合。Collection 接口定义了所有集合类型(如 List、Set、Queue 等)所共有的基…

LeetCode2352相等行列对

题目描述 给你一个下标从 0 开始、大小为 n x n 的整数矩阵 grid ,返回满足 Ri 行和 Cj 列相等的行列对 (Ri, Cj) 的数目。如果行和列以相同的顺序包含相同的元素(即相等的数组),则认为二者是相等的。 解析 针对题目给出的数量级…

cubemx配置stm32f407VET6实现can通信

背景: 项目上需要把原先的TMC5160电机驱动器替换为购买的电机控制模块(该模块采用canopen通信) 移植canopen的前提是can通信正常,现在添加一下can通信(先用标准帧,250K bit/S的波特率测试) 原理…

个人学习计划

vue前端(一周) 05/14 - 05/19 Html、css复习、vue基础复习、axios复习 05/14 ElementUI学习 05/15 JWT集成验证码、token 05/16 vue-route多角色登录 05/17 增删查改、文件下载 05/18 Echart饼状图 05/19 📌 附加学习: 父子传值三…

其它高阶数据结构②_图(概念+存储+遍历+最小生成树)

目录 1. 图的概念 2. 图的存储结构 2.1 邻接矩阵(后面算法所用) 2.2 邻接表 3. 图的遍历 3.1 BFS广度优先遍历 3.2 DFS深度优先遍历 4. 最小生成树 4.1 Kruskal算法 4.2 Prim算法 本篇完。 1. 图的概念 图是由顶点集合及顶点间的关系组成的一…

重磅!麒麟信安发布CentOS安全加固套件

CentOS Linux 7系统即将在6月30日停服,标志CentOS全部停止更新和维护。党政、金融、能源、通信、交通、公共服务等关键信息基础设施领域已经投运使用的CentOS系统将无法获取官方提供的漏洞修复补丁,此后,CentOS系统将面临巨大的安全风险与危害…

【运维项目经历|003】:Nginx集群化运维升级项目

目录 项目名称 项目背景 项目目标 项目成果 我的角色与职责 我主要完成的工作内容 本次项目涉及的技术 本次项目遇到的问题与解决方法 本次项目中可能被面试官问到的问题 问题1:为什么选择nginx-1.25.4版本,nginx官方最新版本是哪一个版本&…

河南广电与LiblibAI签署战略合作协议

5月15日,河南广电科技与LiblibAI战略签约仪式在郑州中原福塔新闻发布厅隆重举行。双方将本着“共商、共享、共建、共赢”原则,基于全面、可持续的战略合作伙伴关系,发挥各自优势,共同聚焦生成式AI领域,围绕内容创作、商…

CPU占用率过高排查

CPU占用率高是设备本身的一种现象,直观表现为display cpu-usage命令查询结果中整机CPU占用率“CPU usage”偏高,如超过70%。在网络运行中CPU高常常会导致其他业务异常,如BGP震荡、VRRP频繁切换、甚至设备无法登录。 通常,整机CPU占…

Java基础教程 - 7 面向对象-1

更好的阅读体验:点这里 ( www.doubibiji.com ) 更好的阅读体验:点这里 ( www.doubibiji.com ) 更好的阅读体验:点这里 ( www.doubibiji.com ) 7 面向对象 面向对象&am…

无人售货奶柜:掘金新零售蓝海,

无人售货奶柜:掘金新零售蓝海, 在日新月异的商业浪潮中,无人奶柜犹如一股清新的创业飓风,正以不可阻挡之势吸引着众多创业者的目光。这股新兴力量以其独到之处和庞大的市场蓝海,预示着一场关于健康、便捷消费方式的深…

【C#】DateTime类型数组含有null?并排序

代码 internal class Program{static void Main(string[] args){List<DateTime?> dateTimes new List<DateTime?> { null,DateTime.MinValue,DateTime.MaxValue};var temp new List<DateTime?> { };dateTimes.Sort();//dateTimes.Reverse();foreach (va…

石碑之谜:滚动机关

描述 在蒙德和璃月的边界地带&#xff0c;有一个被遗忘的神庙&#xff0c;里面有一个奇怪的机关&#xff1a;滚动石碑。小熊必须操作这个112的长方体石碑&#xff0c;使其通过不同的地面环境&#xff0c;最终放置到神秘的符号“O”上&#xff0c;以解开通往宝藏的大门。 石碑…

Edwards爱德华PHM3000培训PPT课件内容可见图片详情

Edwards爱德华PHM3000培训PPT课件内容可见图片详情

golang encoding/json 使用基础

json 与 encoding/json JSON&#xff08;JavaScript Object Notation&#xff09;是一种轻量级的数据交换格式&#xff0c;它基于 ECMAScript&#xff08;欧洲计算机协会制定的js规范&#xff09;的一个子集&#xff0c;采用完全独立于语言的文本格式来存储和表示数据。简洁和…