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

news2024/12/26 22:03:28

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

更多有关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.coloradmin.cn/o/1679186.html

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

相关文章

node.js的Express框架的介绍 与 安装详细教程

一、Express框架介绍 (1)Express定义: Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮助你创建各种 Web 应用,和丰富的 HTTP 工具。 使用 Express 可以快速地搭建一个完整功能的网站。 &#xff08…

微信小程序快速开发-基础内容(内容真的又多又干货)

目录 实现横向布局效果 实现滚动效果 实现轮播图效果 实现文本长按选中复制效果 渲染 HTML 标签 按钮组件的使用效果 图片组件的使用效果 Mustache 语法 动态绑定内容(定义变量,渲染变量) 动态绑定属性(将属性定义为变量…

2024年中国国际厨卫家居展览会(上海KIB厨卫展)

中国国际厨卫家居博览会(KIB)由中国五金制品协会、中国国际贸易促进委员会轻工行业分会、北京奥维云网大数据科技股份有限公司主办。从最初的“中国国际橱柜、厨房卫浴产品与技术博览会(CIKB)”,到2001年与中国国际五金展&#xf…

LSTM与GAN创新结合!模型性能起飞,准确率超98%

今天来聊一个深度学习领域非常具有创新性的研究方向:LSTM结合GAN。 LSTM擅长处理和记忆长期的时间依赖关系,而GAN可以学习复杂的数据分布并生成逼真的数据样本。通过充分结合两者的优势,我们可以增强模型对复杂数据的处理能力,提…

scanf读取标准输入

内容 scanf函数的原理 多种数据类型混合输入 常用的数据输入/输出函数 程序员可以给程序输入数据,程序处理后会返回一个输出。C语言通过函数库读取标准输入,然后通过对应函数处理将结果打印到屏幕上,printf函数可以将结果打印到屏幕上。下…

英语学习笔记14——What color‘s your ... ?

What color’s your … ? 你的 …… 是什么颜色的? 词汇 Vocabulary case n. 箱子【封闭的】 相关:box n. 箱子【开口的】    bookcase n. 书架 补充:case n. 案件,案例 口语:It’s a small case.    小意思&…

稚晖君独家撰文:具身智能即将为通用机器人补全最后一块拼图

具身智能新纪元。 *本文为稚晖君独家供稿,「甲子光年」经智元机器人授权发布。稚晖君本名彭志辉,先后任职OPPO、华为,现为智元机器人CTO、首席架构师。 在ChatGPT之后,又一个大模型概念火了——具身智能(Embodied AI)。 在学术界,图灵奖得主、上海期智研究院院长姚期…

【数据结构】堆(超详细)

文章目录 前言堆的概念及结构堆的实现堆的向下调整算法(建小堆为例)堆的向上调整算法(建小堆为例)堆的初始化销毁堆堆的插入堆的删除(规定删堆顶的数据)取堆顶元素判断堆是否为空获取堆的个数 完整代码(包括测试代码&a…

解决kali Linux2024无法获取动态IPv4地址(DHCP)解决方案

用root用户启动终端 进入根目录,选择配置文件 cd到根目录下/../etc/network找到interfaces文件 编辑interfaces文件 vi interfaces,编辑interfaces文件 输入如下命令 打开虚拟网络编辑器 选择虚拟机选项卡,编辑,打开虚拟网络编…

【Linux 网络】网络基础(二)(应用层协议:HTTP、HTTPS)-- 详解

我们程序员写的一个个解决我们实际问题,满足我们日常需求的网络程序,都是在应用层。 前面写的套接字接口都是传输层经过对 UDP 和 TCP 数据发送能力的包装,以文件的形式呈现给我们,让我们可以进行应用层编程。换而言之&#xff0c…

50.乐理基础-拍号的类型-混合拍子

混合拍子的定义: 1.由不同的单拍子组合起来的,如图1。 2.因为组合顺序有多种可能,所以次强拍的位置也有多种可能,如图3。 图1:四二拍是单拍子,四三拍也是单拍子,四二拍 与 四三拍就是 不同的单拍…

网络游戏同步技术六:若干问题探讨

本文探讨网络同步的几个问题。 王者荣耀使用帧同步明智吗? 这个很难评,成王败寇,它成功了,它就是明智的。但是帧同步带来的心智负担还是很重的,他们的分享里面也提到他们花了很大的功夫去解决不一致问题。 个人更喜欢…

Sketch总结

sketch禁用了lineGap https://www.sketch.com/docs/designing/text/ http://www.sketchcn.com/sketch-chinese-user-manual.html https://github.com/sketch-hq/sketch-document https://developer.sketch.com/file-format/ https://animaapp.github.io/sketch-web-viewer/ htt…

定时发圈操作介绍

1、登陆已有的账号,点击到"朋友圈"功能 2、选择要发圈的微信号,编辑发圈的文案内容 3、自定义想要的时间点 4、点击"立即发送" 5、可进行跟圈

校园防欺凌平台

校园霸凌事件很难被发现,发现者又可能迫于威胁而不敢告发,被霸凌者又因各种原因而选择忍耐,所以,如果能够在发生校园霸凌的时候,做出及时的预警,也许能够拯救挽回无数个家庭。本平台结合防欺凌设备&#xf…

Transformer - Self-Attention层的复杂度的计算

Transformer - Self-Attention层的复杂度的计算 flyfish 矩阵的维度 下面矩阵的维度是32即 3行,2列 6,10等都是矩阵里的元素 如果矩阵A的列数与矩阵B的行数相同,那么这两个矩阵可以相乘。即,若A是一个mn矩阵,B是一个np矩阵&am…

python文件操作常用方法(读写txt、xlsx、CSV、和json文件)

引言 用代码做分析的时候经常需要保存中间成果,保存文件格式各不相同,在这里好好总结一下关于python文件操作的方法和注意事项 Python 提供了丰富的文件操作功能,允许我们创建、读取、更新和删除文件。允许程序与外部世界进行交互。 文章目录…

用c++实现快速排序、最大子段和问题

6.2.2 快速排序 【问题】快速排序(quick sort)的分治策略如下(图6-5)。 (1)划分:(选定一个记录作为轴值,以轴值为基准将整个序列划分为两个子序列,轴值的位置在划分的过程中确定,并且左侧子序列的所有记录…

mysql主从热备+keepalived 部署mysql高可用主备模式

目录 1、环境准备 2、分别在主服务器和备用服务器上安装keepalived 3、修改keepalived服务的配置文件 3.1 修改主服务器上的keepalive服务的配置文件 3.2 修改备用服务器上的keepalive服务配置文件 4、编写mysql监控脚本放到主服务器上 5、在主服务器和备用服务器上查看…

工厂自动化升级改造(3)-Modbus与MQTT的转换

什么是MQTT,Modbus,见下面文章 工厂自动化升级改造参考(01)--设备通信协议详解及选型-CSDN博客文章浏览阅读608次,点赞9次,收藏6次。>>特点:基于标准的以太网技术,使用TCP/IP协议栈,支持高速数据传输和局域网内的设备通信。>>>特点:跨平台的通信协议,…