【数据结构】树和二叉树及堆的深入理解

【数据结构】树和二叉树及堆的深入理解

🔥个人主页大白的编程日记

🔥专栏数据结构


文章目录

  • 【数据结构】树和二叉树及堆的深入理解
    • 前言
    • 一.树
      • 1.1 树的概念
      • 1.2 树的相关概念
      • 1.3 树的表示
      • 1.4 树的应用
    • 二.二叉树
      • 2.1 二叉树概念及结构
      • 2.3 特殊的二叉树
      • 2.4 二叉树的性质
      • 2.5 二叉树的存储结构
    • 三.堆
    • 后言

前言

哈喽,各位小伙伴大家好!上期我们学习和站和队列。接下来我们学习新的数据结构:树。话不多说,我们进入正题!向大厂冲锋!

一.树

1.1 树的概念

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


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

  • 子树
    除根结点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、……、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
堂兄弟结点:双亲在同一层的结点互为堂兄弟;如上图:H、I互为兄弟结点
结点的祖先:从根到该结点所经分支上的所有结点;如上图:A是所有结点的祖先
子孙:以某结点为根的子树中任一结点都称为该结点的子孙。如上图:所有结点都是A的子孙
森林:由m(m>0)棵互不相交的树的集合称为森林

1.3 树的表示

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

  • 孩子表示法
    明确树的度
    用指针数组表示节点的孩子
typedef int DataType;
struct Node
{
 DataType val;
 struct Node* subs[N]; //指针数组表示节点的孩子
};

不知道树的度
那就用动态的指针数组表示节点的孩子

typedef int DataType;
struct Node
{
 DataType val;
 struct Node** arr; //指向指针数组首元素的指针
};
  • 孩子兄弟法

用一个指针指向左边第一个的孩子,一个指针指向右边的兄弟。

typedef int DataType;
struct Node
{
 struct Node* firstChild1; // 第一个孩子结点
 struct Node* pNextBrother; // 指向其下一个兄弟结点
 DataType data; // 结点中的数据域
};


这样我们找到左边的第一个孩子,在通过孩子的兄弟指针就可以找到所有的孩子节点。

1.4 树的应用

其实window系统就是森林。里面的C盘和D盘就是构成森林的多棵树。

所以有时候又叫目录树。

二.二叉树

2.1 二叉树概念及结构

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

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

树的度最大为2就是二叉树。
度为0,1,2都可以只要度不超过2就是二叉树

  1. 二叉树不存在度大于2的结点
  2. 二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树

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

2.3 特殊的二叉树

  • 满二叉树

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


满二叉树除了最后一层度为0,其他节点都是度为2.

  • 完全二叉树

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


完全二叉树的前h-1层都是满二叉树,最后一层的节点从左到右必须连续。最后一层可以满也可以不满。

注意满二叉树是特殊的完全二叉树,完全二叉树不一定是满二叉树。

2.4 二叉树的性质

  • 若规定根结点的层数为1,则一棵非空二叉树的第i层上最多有2^(i-1) 个结点.

  • 若规定根结点的层数为1,则深度为h的二叉树的最大结点数是 2^h-1.

  • 对任何一棵二叉树, 如果度为0其叶结点个数为n0, 度为2的分支结点个数为n2,则有 n0=n2+1

  • 证明

2.5 二叉树的存储结构

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

  • 链式结构

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


链式结构就是用链表表示一个树节点,每个节点存储当前节点的数据,以及两个指针指向节点的孩子。三叉链表就会一个指针父亲节点的指针。

typedef int BTDataType;
// 二叉链
struct BinaryTreeNode
{
 struct BinTreeNode* left; // 指向当前结点左孩子
 struct BinTreeNode* right; // 指向当前结点右孩子
 BTDataType data; // 当前结点值域
}
// 三叉链
struct BinaryTreeNode
{
 struct BinTreeNode* parent; // 指向当前结点的双亲
 struct BinTreeNode* left; // 指向当前结点左孩子
 struct BinTreeNode* right; // 指向当前结点右孩子
 BTDataType data; // 当前结点值域
}
  • 顺序结构

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

顺序结构就是用顺序表将树节点的值按顺序存储,那如何找到孩子节点,又如何找到孩子节点的父亲节点呢?

顺序结构需要通过下标根据父亲节点和孩子节点的下标关系从而找到两者。

三.堆

如果有一个关键码的集合K = { , , ,…, },把它的所有元素按完全二叉树的顺序存储方式存储在一个一维数组中,并满足: <= 且 <= ( >= 且 >= ) i = 0,1,2…,则称为小堆(或大堆)。将根结点最大的堆叫做最大堆或大根堆,根结点最小的堆叫做最小堆或小根堆。

简单来说堆满足两个条件:

  • 首先必须是完全二叉树
  • 任何一个父亲节点的值都>=或<=他的孩子节点的值。
    如果是大堆父亲节点的值都>=他的孩子节点的值。
    如果是小堆父亲节点的值都<=他的孩子节点的值。
    所以大堆的根就是堆的最大值,小堆就是堆的最小值。
    这就可以用这个特性来做堆排序。
    在这里插入图片描述
    那大堆的顺序结构就是降序,小堆就是升序吗?

    不能因为,兄弟节点的关系不能根据大小堆确定。

后言

这就是树,二叉树,堆的概念和理解了。这是数据结构很重要的内容,咱们一定要多加学习和掌握。今天就分享到这里,感谢大家的耐心垂阅!咱们下期见!拜拜~

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

el-table和 el-image图片预览使用插槽后层叠样式错乱问题

问题&#xff1a; 解决办法&#xff1a;在el-image组件中添加preview-teleported 属性 最终效果

二百四十四、Hive——Hive中解析复杂JSON,既有对象还有数组,而且数组中包含数组

一、目的 由于协议修改&#xff0c;修改后的原始数据JSON更加复杂&#xff0c;导致Hive中解析的难度更大&#xff0c;搞了一天&#xff0c;还好同事发了篇知乎文章&#xff0c;终于得以解决&#xff0c;天哪&#xff0c;太不容易了 二、数据协议案例 { "deviceNo&qu…

elasticsearch-keystore工具介绍

1、参数设置查询 命令格式&#xff1a; bin/elasticsearch-keystore list 2、密码密码查询 命令格式: bin/elasticsearch-keystore show 参数 例&#xff1a;bin/elasticsearch-keystore show xpack.security.http.ssl.keystore.secure_password

linux系统 mysql-8.0.32安装

1、下载安装文件 此处我选择的是 Archives 8.0.32版本 2、上传文件到linux服务器 此处省略 3、卸载旧版本mysql // 查看现有mysql&#xff1a; rpm -qa|grep -i mysql// 查看mysql状态 systemctl status mysqld.service// 若为启用状态&#xff0c;则停止 systemctl stop…

html5——CSS列表样式属性

list-style-type list-style-image list-style-position list-style eg&#xff1a; li { list-style:none; }【去除前面的黑点】

对象存储解决方案:高性能分布式对象存储系统MinIO

文章目录 引言I 自动化数据管理界面1.1 图形用户界面:GUI1.2 命令行界面:MinIO CLI1.3 应用程序编程接口:MinIO APIII 部署集成2.1 静态端口分配2.2 将NGINX用作反向代理,配置负载。III 基础概念3.1 为什么是对象存储?3.2 MinIO支持哪些系统拓扑结构?3.3 时间同步3.4 存储…

分布式 I/O 系统 BL200 Modbus TCP 耦合器

BL200 耦合器是一个数据采集和控制系统&#xff0c;基于强大的 32 位微处理器设计&#xff0c;采用 Linux 操作系统&#xff0c;支持 Modbus 协议&#xff0c;可以快速接入现场 PLC、SCADA 以及 ERP 系统&#xff0c; 内置逻辑控制、边缘计算应用&#xff0c;适用于 IIoT 和工业…

CyberVadis认证是什么

CyberVadis认证是一项全球性的、权威的、基于云的网络安全性评估和认证项目。它是由Altimeter公司开发的&#xff0c;专门针对云计算服务提供商、数据中心、软件即服务(SaaS)供应商、安全咨询服务公司和内部IT部门而设计的。 CyberVadis认证旨在评估和验证组织在网络安全方面的…

android中实现双列表联动功能

就是一个数据展示的功能&#xff0c;左边是目录、右边是详情列表。效果图如下&#xff1a; 实现的思路&#xff0c;就是左右一个列表&#xff0c;右边的列表里面嵌套一个列表&#xff0c;一共三个列表。 第一步&#xff1a;先写一个主页面布局文件 <?xml version"1…

在GPU上运行PyTorch

文章目录 1、查看GPU的CUDA版本2、下载CUDA版本3、安装cuDNN4、配置CUDA环境变量5、安装配置Anaconda6、使用Anaconda7、pycharm导入虚拟环境8、安装带GPU的PyTorch⭐9、总结 &#x1f343;作者介绍&#xff1a;双非本科大三网络工程专业在读&#xff0c;阿里云专家博主&#x…

轻量级自适用商城卡密发卡源码(可运营)

一款全开源非常好看的发卡源码。轻量级自适应个人自助发卡简介&#xff0c;这是一款二次开发的发卡平台源码修复原版bug,删除无用的代码。所有文件全部解密&#xff0c;只保留后台版权信息内容。大家放心使用&#xff0c;可以用于商业运营。轻量级自适应个人自助发卡。 源码下…

【海外云手机】静态住宅IP集成解决方案

航海大背景下&#xff0c;企业和个人用户对于网络隐私、稳定性以及跨国业务的需求日益增加。静态住宅IP与海外云手机的结合&#xff0c;提供了一种创新的集成解决方案&#xff0c;能够有效应对这些需求。 本篇文章分为三个部分&#xff1b;静态住宅优势、云手机优势、集成解决…

高翔【自动驾驶与机器人中的SLAM技术】学习笔记(一)——流形;

新建了一个专栏&#xff0c;仔细学习高翔的新书《自动驾驶与机器人中的SLAM技术》。 快速通读了一遍&#xff0c;发现还有很多需要深入学习的东西&#xff0c;因此二刷这本书。对于自己不懂的地方&#xff0c;通过这个笔记记录这个流程。 第一个问题&#xff1a;流形。 流形学…

Spring Boot项目的404是如何发生的

问题 在日常开发中&#xff0c;假如我们访问一个Sping容器中并不存在的路径&#xff0c;通常会返回404的报错&#xff0c;具体原因是什么呢&#xff1f; 结论 错误的访问会调用两次DispatcherServlet&#xff1a;第一次调用无法找到对应路径时&#xff0c;会给Response设置一个…

uniapp页面跳转传参和动态修改NavigationBarTitle

一、需求 比如聊天界面&#xff0c;需要在上方展示对方的名字&#xff0c;我们这样需要动态数值的&#xff0c;就不能写在pages配置项里面。 二、实现 我们并没有在pages里面配置固定的title名&#xff0c;我们需要动态传到talk&#xff0c;然后动态修改绑定到这个title。好在u…

从零开始学量化~Ptrade使用教程(六)——盘后定价交易、港股通与债券通用质押式回购

盘后固定价交易 实现科创板、创业板的盘后固定价交易&#xff0c;界面如下显示&#xff1a; 交易 输入科创板或创业板代码&#xff0c;选择委托方向&#xff0c;输入委托价格、委托数量&#xff0c;点击“买入”或“卖出”按钮进行委托。可出现一个委托提示框提示是否继续委托操…

HCNA VRP基础

交换机可以隔离冲突域&#xff0c;路由器可以隔离广播域&#xff0c;这两种设备在企业网络中应用越来越广泛。随着越来越多的终端接入到网络中&#xff0c;网络设备的负担也越来越重&#xff0c;这时网络设备可以通过专有的VRP系统来提升运行效率。通过路由平台VRP是华为公司数…

怎么录屏?Windows和Mac电脑都适用的3种方法

在数字化时代的浪潮中&#xff0c;电脑录屏已经成为一种必备技能。无论是为了制作教学视频&#xff0c;记录游戏的高光时刻、还是为了保存下欢乐时光&#xff0c;录屏功能都在我们当中发挥着重要的作用。但是怎么录屏也成为一个难题&#xff0c;有时候用的电脑不一样&#xff0…

基于搜索二叉树的停车收费管理系统

系统效果&#xff1a;录入汽车信息 查看汽车信息 收费信息查看 查询车库车辆 代码展示&#xff1a; //SearchBinaryTree.h #pragma once #include<iostream> #include<string> #include<time.h> #include<Windows.h> using namespace std;template<…

ArkTS学习笔记_UI界面的状态管理简述

ArkTS学习笔记_UI界面的状态管理简述 背景&#xff1a; 我们在UI开发中&#xff0c;绝大多数的UI界面都是动态的、有用户交互的&#xff0c;为了实现动态交互&#xff0c;引入了一个概念“状态”&#xff0c;它主要是用来记录管理UI界面的状态变化&#xff08;数据变化&#x…