【数据结构初阶】二叉树--基本概念

news2024/9/24 15:26:47

hello!

目录

一、树

1.1  树的概念和结构

1.2  树的相关术语 

1.3  树的表示

1.4  树形结构实际应用场景

二、二叉树

2.1  概念和结构

2.2  特殊的二叉树

2.2.1  满二叉树

2.2.2  完全二叉树

2.3  二叉树的存储结构

2.3.1  顺序结构

2.3.2  链式结构

Relaxing Time!

  ——————————  爱的华尔兹  ——————————


一、树

1.1  树的概念和结构

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

  • 有一个特殊的结点,称为根节点,根节点没有前驱结点。
  • 除根结点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、...、Tm,其中每一个集合Ti(1<=i<=m)又是一棵结构与树类似的子树。每棵子树的结点有且只有一个前驱,可以有0个或多个后继。因此,树是递归定义的。
  • 子树是不能相交的。(如果相交就是图了)。
  • 除了根结点之外,每个结点有且只有一个父结点。
  • 一棵N个结点的树有N-1条边。

【注意】

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

非树形结构:

1.2  树的相关术语 

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

子结点/孩子结点:一个结点含有的子树的根结点称为该结点的子结点,;B是A的子结点。

结点的度:一个结点有几个孩子,它的度就是多少;A的度为6,E的度为2。

树的度:一棵树中,最大的结点的度称为树的度;;该树的度为6。

叶子结点/终端结点:度为0的结点称为叶结点;B、C、O、P结点等都为叶子结点。

分支结点/非终端结点(非叶子结点):度不为0的结点;A、D、E等结点。

兄弟结点:具有相同父结点的结点互称为兄弟结点(亲兄弟);M和N为兄弟结点。

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

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

结点的祖先:从根到该结点所经分支上的所有结点;A是所有结点的祖先。

路径:一条从树中任意结点出发,沿父结点到子结点连接,达到任意结点的序列;如,从A到P的路径为:A-E-J-P,H到P:H-D-A-E-J-P。

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

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

1.3  树的表示

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

struct TreeNode
{
    struct Node* child;  //左边开始的第一个孩子结点
    struct Node* brother;//指向其右边的下一个兄弟结点
    int data;            //结点中的数据域
}

1.4  树形结构实际应用场景

文件系统是计算机存储和管理文件的一种方式,它利用树形结构来组织和管理文件和文件夹。在文件系统中,树结构被广泛应用,它通过父结点和子结点之间的关系来表示不同层级文件和文件夹之间的关联。

二、二叉树

2.1  概念和结构

在树形结构中,我们最常用的就是二叉树,一棵二叉树是结点的一个有限集合,该集合由一个根结点加上两棵别称为左子树右子树的二叉树组成或者为空。

从图中看出二叉树具备以下特点:

  • 二叉树不存在度大于2的结点(二叉树只存在度为0,1,2);
  • 二叉树的子树有左右之分,次序不能颠倒,因此二叉树是有序树;

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

现实中的二叉树

2.2  特殊的二叉树

2.2.1  满二叉树

一个二叉树,如果每一层的结点数都达到最大值,则这个二叉树就是满二叉树。也就是说,如果一个二叉树的层数为K,且结点总数是2^(k-1),则它就是满二叉树。(结点总数由等比数列求和得出)

满二叉树

2.2.2  完全二叉树

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

通俗点来讲,假设二叉树层次为k,除了第k层之外,每层结点的个数都达到了最大结点数,第k层结点个数不一定达到最大结点数,完全二叉树结点的顺序是从左到右的。

满二叉树一定是完全二叉树,但是,完全二叉树不一定是满二叉树。

根据满二叉树的特点可知:

  • 若规定根结点的层数为1,则一棵非空二叉树的第i层上最多有2^(i-1)个结点;
  • 若规定根结点的层数为1,则深度为h的二叉树的最大结点数是2^h -1;
  • 若规定根结点的层数为1,具有n个结点的满二叉树的深度h=log2(n+1),log以2为底,n+1为对数。

2.3  二叉树的存储结构

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

2.3.1  顺序结构

顺序结构存储就是使用数组来存储,一般使用数组只适合表示完全二叉树,因为不是完全二叉树会有空间的浪费,完全二叉树更适合使用顺序结构存储。

现实中我们通常把堆(一种二叉树)使用顺序结构的数组来存储,需要注意的是这里的堆和操作系统模拟进程地址空间中的堆是两回事,一个是数据结构,一个是操作系统中管理内存的一块区域分段。

2.3.2  链式结构

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

至此,二叉树的相关概念学习结束!

完——


Relaxing Time!

  ————————————  爱的华尔兹  ————————————

【爱的华尔兹_俞灏明_高音质在线试听_爱的华尔兹歌词|歌曲下载_酷狗音乐】

我是云边有个稻草人

期待我们的下一次相遇!

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

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

相关文章

转行到大模型,完整版攻略从大模型零基础到大模型精通,我是这样过来的

在当今这个日新月异的时代&#xff0c;技术的更新迭代速度远超我们的想象。对于那些渴望在职业生涯中寻求新挑战的人来说&#xff0c;转向人工智能领域&#xff0c;尤其是投身于大规模语言模型的研究与开发&#xff0c;无疑是一个充满机遇的选择。本文将为您揭示如何从零开始&a…

阿里十万卡训练集群 网络拓扑架构和优势 Alibaba HPN: A Data Center Network for Large Language Model Training

本博客的视频教程在这&#xff1a; 2.2阿里十万卡集群 网络拓扑架构和优势 Alibaba HPN: A Data Center Network for Large Language Model_哔哩哔哩_bilibili 一、大模型训练的核心问题 1.1 流量模式的问题 大语言模型训练的流量模式问题可参考这个&#xff1a; ECMP等价…

Linux 服务器下非root用户安装CUDA完整流程(多次踩雷经验总结)

参考博客&#xff1a; linux下安装cuda和cudnn&#xff08;非root权限&#xff09;_cuda下载安装 远程服务器 linux-CSDN博客 Linux下非root用户安装CUDA_linux下cuda-toolkit-archive-CSDN博客 非root用户安装cuda10.1&#xff0c;以及CUDA不同版本间切换_非root用户.run文…

已解决centos7 yum报错:cannot find a valid baseurl for repo:base/7/x86_64的解决方案

出现cannot find a valid baseurl for repo:base/7/x86_64错误通常是由于YUM仓库源无法找到或无法访问&#xff0c;导致YUM无法正常工作。这种情况常见于CentOS 7系统。解决这个问题需要检查几个方面&#xff0c;如网络连接、DNS设置和YUM仓库源配置。 &#x1f9d1; 博主简介&…

aspose-words中插入附件及遇到的问题

aspose-words版本&#xff1a;21.1 java&#xff1a;1.8 目标&#xff1a; 前端使用tinymce编辑一段内容&#xff0c;后端使用aspose-words将html转为word&#xff0c;并将html中的附件转换为word中的附件。 形如&#xff1a; 实现方案&#xff1a; 使用正则表达式找出需要替…

setData的 Qt::CheckStateRole是model中checkbox的状态(选中否)

checkbox的状态 bool MissionModel::setData(const QModelIndex &index, const QVariant &value, int role) { if (role Qt::CheckStateRole && col 3 ) { } }

【嵌入式裸机开发】基于stm32的照相机(OV7670摄像头、STM32、TFTLCD)

基于STM32的照相机 准备工作最终效果一、下位机1、主函数2、OV7670初始化 二、上位机1、控制拍照2、接收图片数据 准备工作 一、硬件及片上资源: 1,串口1(波特率:921600,PA9/PA10通过usb转ttl连接电脑&#xff0c;或者其他方法)上传图片数据至上位机 2,串口2(波特率:115200,PA…

Opencv学习-直方图应用

1. 直方图均衡化 如果一个图像的直方图都集中在一个区域&#xff0c;那么整体图像的对比度比较小&#xff0c;不便于图像中纹理的识别。例如&#xff0c;如果相邻的两个像素灰度值分别是 120 和 121 &#xff0c;那么仅凭肉眼是无法区别出来的。同时&#xff0c;如果图像中所…

音频提取软件分享:6款好用音频提取工具推荐

在现代数字媒体中&#xff0c;音频提取已经成为一项至关重要的技能。无论你是视频创作者、播客主持人&#xff0c;还是音乐爱好者&#xff0c;从视频、电影或其他多媒体文件中提取音频&#xff0c;都是一项非常有用的操作。 本文将围绕音频提取&#xff0c;介绍这项技术的应用、…

一篇文章带你实现大模型及RAG入门---小白速进

项目概述&#xff1a;随着人工智能技术的飞速发展&#xff0c;大模型&#xff08;Large Models&#xff09;和检索增强型生成&#xff08;Retrieval-Augmented Generation, RAG&#xff09;已成为自然语言处理&#xff08;NLP&#xff09;领域的热点。大模型以其强大的理解和生…

Java二十三种设计模式-责任链模式(17/23)

责任链模式&#xff1a;实现请求处理的灵活流转 引言 在这篇博客中&#xff0c;我们深入探讨了责任链模式的精髓&#xff0c;从其定义和用途到实现方法&#xff0c;再到使用场景、优缺点、与其他模式的比较&#xff0c;以及最佳实践和替代方案&#xff0c;旨在指导开发者如何…

力扣第 411 场周赛题解

3258. 统计满足 K 约束的子字符串数量 I 给你一个 二进制 字符串 s 和一个整数 k。 如果一个 二进制字符串 满足以下任一条件&#xff0c;则认为该字符串满足 k 约束&#xff1a; 字符串中 0 的数量最多为 k。字符串中 1 的数量最多为 k。 返回一个整数&#xff0c;表示 s …

系统编程-进程初步1

5 进程初步 一、认识进程 -- 进程Process是指计算机中已运行的程序&#xff0c;是系统进行资源分配和调度的基本单位&#xff0c;是操作系统结构的基础 -- 程序运行起来就是一个进程 进程存在于运行内存中程序存在于硬盘中 -- windows下查看进程使用任务管理器进行查看 1…

EXCEL——Vlookup17个高级用法

大纲 一、基本语法 1、参数详解 二、入门篇 1、单条件查找 2、屏蔽查找返回的错误值 三、进阶篇 1、反向查找 2、包含查找 3、区间查找 4、含通配符查找 5、多列查找 6、多区域查找 四、高级篇 1、多条件查找 2、合并单元格查找 3、带合并单元格的多条件查找 …

轻松玩转音频剪辑:推荐四大必备工具!

在这个多媒体时代&#xff0c;音频剪辑技能变得至关重要。无论是制作短视频、音频节目&#xff0c;还是音乐创作&#xff0c;一款得心应手的音频剪辑工具都能让你事半功倍。今天&#xff0c;我们将推荐几款热门音频剪辑工具&#xff0c;助你轻松玩转声音世界 福昕音频剪辑 链…

【数学建模】趣味数学模型——等额还款数学模型

问题 在银行贷款中&#xff0c;通常采用等额还款。假定银行贷款的年利率为 p&#xff0c;贷款 k 元&#xff0c;分 m 年采用每月等额还款方式还清。问每月还款多少钱&#xff1f;总共还的钱是多少&#xff1f;每月还款中还本金和利息各是多少元&#xff1f; 如果考虑每月等额…

Webrtc之SDP协议

SDP简介 SDP 最常用于 RTC 实时通话的协商过程&#xff0c;在 WebRTC 中&#xff0c;通信双方在连接阶段使用 SDP 来协商后续传输过程中使用的音视频编解码器(codec)、主机候选地址、网络传输协议等。 在实际的应用过程中&#xff0c;通信双方可以使用 HTTP、WebSocket、Data…

MySQL数据库主从复制

主从复制原理 MySQL的复制类型 基于语句的复制 &#xff08;默认&#xff09;基于行的复制混合类型的复制MySQL主从复制的工作过程 主从复制设置 主从复制时基于二进制文件的所以需要打开二进制文件 主数据库 在MySQL配置文件/etc/my.cnf修改或增加 #启用了MySQL的二进制日…

集合及数据结构第三节————包装类和简单认识泛型

系列文章目录 集合及数据结构第三节————包装类和简单认识泛型 包装类和简单认识泛型 基本数据类型和对应的包装类装箱和拆箱泛型泛型类的使用裸类型(Raw Type) &#xff08;了解&#xff09;泛型如何编译的泛型的上界泛型方法 文章目录 系列文章目录集合及数据结构第三节…

linux上常见问题

1.普通用户下&#xff0c;不能使用sudo 解决方法 1.切换到root用户下执行该指令是没有问题的 2.更改配置文件sudoers 1.进入root用户下&#xff1a;su - 2.编辑sudoers :visudo 此时就打开了一个文件 3.在该文件找到这么一行内容&#xff1a;root ALL(ALL) ALL 4.在该行的…