数据结构之二叉树(上)

news2024/9/17 8:25:13

文章目录

  • 前言
  • 一、二叉树的定义
  • 二、二叉树的几种情况
  • 三、特殊的二叉树
    • 1. 满二叉树
    • 2. 完全二叉树
  • 四、二叉树的存储结构
    • 1. 顺序存储
    • 2. 链式存储
  • 五、二叉树的性质
  • 总结


前言

本文主要介绍了二叉树的基本概念以及二叉树的存储结构


一、二叉树的定义

一棵二叉树是结点的一个有限集合,该集合可以是空集合,也可以是由一个根节点加上两棵别称为左子树和右子树的二叉树组成。

注意:

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

二、二叉树的几种情况

对于任意的二叉树都是由以下几种情况复合而成的
在这里插入图片描述

三、特殊的二叉树

1. 满二叉树

一个二叉树,如果每一个层的结点数都达到最大值,则这个二叉树就是满二叉树。
也就是说,如果一个二叉树的层数为K,且结点总数是​​​​ 2 k − 1 2^{k} - 1 2k1,则它就是满二叉树。
在这里插入图片描述

2. 完全二叉树

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

四、二叉树的存储结构

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

1. 顺序存储

即,使用数组来存储二叉树各个节点的值。
一般只有在表示完全二叉树时,会使用数组。因为其它二叉树会存在空间浪费。
在这里插入图片描述

二叉树顺序存储在物理上是一个数组,在逻辑上是一颗二叉树。
在这里插入图片描述

2. 链式存储

即,用链表来表示一棵二叉树。
一般情况下,链表中每个结点由三个域组成:数据域和左右指针域。
左右指针分别用来指向该结点左孩子和右孩子所在的链结点 。
链式结构又分为二叉链和三叉链,当前我们学习中一般都是二叉链,之后的高阶数据结构中的红黑树等会用到三叉链。
在这里插入图片描述

//二叉链
typedef int BTDataType;
struct BinaryTreeNode
{
	BTDataType data;//当前节点的值域
	struct BinaryTreeNode* pleft;//指向当前节点的左孩子
	struct BinaryTreeNode* pright;//指向当前节点的右孩子
};

//三叉链
typedef int BTDataType;
struct BinaryTreeNode
{
	BTDataType data;//当前节点的值域
	struct BinaryTreeNode* pleft;//指向当前节点的左孩子
	struct BinaryTreeNode* pright;//指向当前节点的右孩子
	struct BinaryTreeNode* pparent;//指向当前节点的父节点
};

五、二叉树的性质

1.若规定根节点的层数为1,则一棵非空二叉树的第i层上结点个数最多为 2 i − 1 2^{i-1} 2i1
2.若规定根节点的层数为1,则深度为h的二叉树的最大结点数是 2 i − 1 2^{i} - 1 2i1
3. 对任何一棵二叉树, 如果度为0的叶结点的个数为 n 0 n_{0} n0 , 度为2的分支结点个数为 n 2 n_{2} n2 ,则有 n 0 n_{0} n0 n 2 n_{2} n2+1。
4. 若规定根节点的层数为1,具有n个结点的满二叉树的深度,h= l o g 2 ( n + 1 ) log_{2}(n + 1) log2(n+1)。(ps: l o g 2 ( n + 1 ) log_{2}(n + 1) log2(n+1)是log以2
为底,n+1为对数)
5. 对于具有n个结点的完全二叉树,如果按照从上至下从左至右的数组顺序对所有节点从0开始编号,则对于序号为i的结点有:

  1. 若i>0,i位置节点的双亲序号为(i-1)/2;
    若i=0,i为根节点编号,无双亲节点
  2. 若2i+1<n,左孩子序号为2i+1
    若2i+1>=n,则无左孩子
  3. 若2i+2<n,右孩子序号:2i+2
    若2i+2>=n,则无右孩子
    这样计算二叉树中某节点的左右子孩子以及父节点的方法,原因是二叉树的存储结构

总结

以上就是今天要讲的内容,本文介绍了主要介绍了二叉树的基本概念。本文作者目前也是正在学习数据结构的相关的知识,如果文章中的内容有错误或者不严谨的部分,欢迎大家在评论区指出,也欢迎大家在评论区提问、交流。
最后,如果本篇文章对你有所启发的话,希望可以多多支持作者,谢谢大家!

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

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

相关文章

Fortinet 发布《2022下半年度全球威胁态势研究报告》,七大发现值得关注!

全球网络与安全融合领域领导者Fortinet&#xff08;NASDAQ&#xff1a;FTNT&#xff09;&#xff0c;近日发布《2022 下半年度全球威胁态势研究报告》。报告指出&#xff0c;相对于组织攻击面的不断扩大以及全球威胁态势的持续演进&#xff0c;网络犯罪分子设计、优化技术与战术…

助你加速开发效率!告别IDEA卡顿困扰的性能优化技巧

在现代软件开发中&#xff0c;IDE&#xff08;集成开发环境&#xff09;是一个必不可少的工具。IntelliJ IDEA是一个广受欢迎的IDE&#xff0c;但有时候IDE的性能可能会受到影响&#xff0c;导致开发人员的工作效率降低。本文将介绍一些可以提高IDE性能的技巧&#xff0c;帮助开…

yii2项目使用frp https2http插件问题

yii2内网项目&#xff0c;使用frp进行内网穿透&#xff0c;使用 https2http插件把内网服务器http流量转成https&#xff0c;会存在一个问题&#xff1a;当使用 $this->redirect(...) 或 $this->goHome() &#xff08;其实用的也是前者&#xff09;等重定向时&#xff0c;…

JavaScript 高级3 :函数进阶

JavaScript 高级3 &#xff1a;函数进阶 Date: January 19, 2023 Text: 函数的定义和调用、this、严格模式、高阶函数、闭包、递归 目标&#xff1a; 能够说出函数的多种定义和调用方式 能够说出和改变函数内部 this 的指向 能够说出严格模式的特点 能够把函数作为参数和返…

Spring Boo集成RocketMQ

一、介绍 Producer&#xff1a;生产者&#xff0c;用来发送消息Consumer&#xff1a;消费者&#xff0c;用来消费消息NameServer&#xff1a;服务注册中心&#xff0c;用于注册生产者、消费者&#xff0c;存储Broker路由 并提供给生产者和消费者Broker&#xff1a;用于存储消息…

【源码】Java版云HIS系统:公立二甲医院应用三年 系统运行稳定、功能齐全

SaaS模式Java版云HIS系统源码&#xff0c;拥有自主知识产权&#xff0c;采用前后端分离架构&#xff0c;前端由Angular语言、JavaScript开发&#xff1b;后端使用Java语言开发。具有强大的可扩展性&#xff0c;二次开发方便快捷。 文末卡片获取联系&#xff01; SaaS模式Java版…

Python 开发-批量 FofaSRC 提取POC 验证

数据来源 学习内容和目的&#xff1a; ---Request 爬虫技术&#xff0c;lxml 数据提取&#xff0c;异常护理&#xff0c;Fofa 等使用说明---掌握利用公开或 0day 漏洞进行批量化的收集及验证脚本开发Python 开发-某漏洞 POC 验证批量脚本---glassfish存在任意文件读取在默认4…

canal admin管理端配置(二)

下载安装 下载地址&#xff1a; 下载解压即可 配置 修改canal.admin-1.1.5\conf\application.yml server:port: 8089 #端口根据是否冲突修改 spring:jackson:date-format: yyyy-MM-dd HH:mm:sstime-zone: GMT8spring.datasource:address: 192.0.16.12:3306#数据库ip和端口…

Day09-网页布局实战定位

文章目录网页布局实战一 表格案例1-单元格的合并案例2-随堂练习二 定位1 文档流2 position 共有四个属性值:3 固定定位案例1-右下角广告案例2-头部固定案例3-div居中4 相对定位案例1-基础案例案例2-文字居于水平线中间5 绝对定位案例1-基础案例6 定位的层次关系 z-index案例1踩…

免费下载丨一看即会,Serverless 技术进阶必读百宝书

过去一年&#xff0c;全球正在加速推进云计算的 Serverless 化进程。Serverless 架构已经逐渐从“被接受”走向了“被学习”和“被应用”。云的产品体系正在 Serverless 化&#xff0c;从计算、存储、数据库到中间件&#xff0c;越来越多的云产品采用了 Serverless 模式。服务器…

筑基九层 —— 指针详解

目录 前言&#xff1a; 指针详解 前言&#xff1a; 1.CSDN由于我的排版不怎么好看&#xff0c;我的有道云笔记比较美观&#xff0c;请移步有道云笔记 2.修炼必备 1&#xff09;入门必备&#xff1a;VS2019社区版&#xff0c;下载地址&#xff1a;Visual Studio 较旧的下载 -…

现代卷积神经网络(GoogleNet),并使用GoogleNet进行实战CIFAR10分类

专栏&#xff1a;神经网络复现目录 本章介绍的是现代神经网络的结构和复现&#xff0c;包括深度卷积神经网络&#xff08;AlexNet&#xff09;&#xff0c;VGG&#xff0c;NiN&#xff0c;GoogleNet&#xff0c;残差网络&#xff08;ResNet&#xff09;&#xff0c;稠密连接网络…

【Hello Linux】进程控制 (内含思维导图)

作者&#xff1a;小萌新 专栏&#xff1a;Linux 作者简介&#xff1a;大二学生 希望能和大家一起进步&#xff01; 本篇博客简介&#xff1a;简单介绍下进程的控制 包括进程启动 进程终止 进程等待 进程替换等概念 进程控制介绍进程创建fork函数fork函数的返回值fork函数的使用…

利用Cookie劫持+HTML注入进行钓鱼攻击

目录 HTML注入和cookie劫持&#xff1a; 发现漏洞 实际利用 来源 HTML注入和cookie劫持&#xff1a; HTML注入漏洞一般是由于在用户能够控制的输入点上&#xff0c;由于缺乏安全过滤&#xff0c;导致攻击者能将任意HTML代码注入网页。此类漏洞可能会引起许多后续攻击&#…

高德地图绘制图层

效果图&#xff1a; //初始数据 data(){return{//地图map:{address:,map:null,//当前鼠标绘制mouseTool:null,//当前编辑polyEditor:null,//覆盖物的绘制点【用于编辑】mouseToolArr:[],//覆盖物的poly对象polyArr:[],//地图右侧功能按钮signNumber:0,//保存提交的覆盖物的点数…

win10添加右键菜单打开VSCode

当进入一个文件夹后&#xff0c;想右键直接打开我的工程&#xff0c;用发现没有vscode项。 我了方便&#xff0c;把 VSCode添加到右键菜单吧。 1. 在桌面新建一个txt文档&#xff0c;用文本编辑器打开 2. 查看vscode所在位置 在桌面找到vscode快捷键图标&#xff0c;右键--&g…

2023年考PMP真的有用吗?含备考资料分享~

对于项目管理者来说&#xff0c;是真的有用&#xff0c;前提是你真的学进去了&#xff0c;是为了学习而考&#xff0c;而不是为了考证而考&#xff0c;考试的作用不是为了让你得到证书&#xff0c;而是考校你的水平&#xff0c;知识是知识&#xff0c;经验是经验&#xff0c;缺…

【浅学Java】MySQL索引七连炮

MySQL索引面试七连炮0. 谈一下你对索引的理解1. MySQL索引原理和数据结构能介绍一下吗2. B树和B树的区别3. MySQL聚簇索引和非聚簇索引的区别4. 使用MySQL索引都有什么原则4.1 回表4.2 索引覆盖4.3 最左匹配4.4 索引下推5. 不同的存储引擎是如何进行数据的存储的6. MySQL组合索…

根据文件内容批量更改文件名称

注意的问题&#xff1a; ★★★待处理的文件顺序要与excel中新的文件名称顺序一致&#xff0c;我直接复制文件地址到excel中顺序与原来顺序不一样&#xff0c;也不能通过排序得到原来的顺序&#xff0c;这里给出一种解决办法&#xff0c;具体步骤见2数据预处理阶段。 1. 这是我…

最新版本OpenAI怎么调试--用Postman调试最新版OpenAI-API

动动小手指&#xff0c;去到openai的API介绍页面。 https://platform.openai.com/docs/api-reference/models 通过官网的提示&#xff0c;可以copy对应的调试命令进行测试。 本文主要通过curl命令实现。 打开Postman&#xff0c;对&#xff0c;就是那个测试接口用的postman ​…