二叉树——存储结构

二叉树的存储结构

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

一、顺序存储

      二叉树的顺序存储是指用一组连续的存储单元依次自上而下自左至右存储完全二叉树上的结点元素,即将完全二叉树上编号为i的结点元素存储在一维数组下标为i-1的分量中。

依据二叉树的性质,完全二叉树满二叉树采用顺序存储比较合适,树中结点的序号可以唯一地反映结点之间的逻辑关系,既最大可能地节省存储空间,且可以利用数组元素的下标值确定结点在二叉树中的位置,以及结点之间的关系。但对于一般的二叉树,为了让数组下标能反映二叉树中结点之间的逻辑关系,只能添加一些并不存在的空结点大让其每个结点与完全二叉树上的结点相对照,再存储到一维数组的相应分量中。

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

例:二叉树的顺序存储中,一定要把二叉树的节点编号与完全二叉树对应起来

* i的左孩子     ——2i

* i的右孩子     ——2i+1

* i的父节点     ——[i/2]

在最坏情况下:高度为h且只有h个结点的单支树(所有结点只有右孩子)也至少需要2h-1个存储单元。其中0表示并不存在的空结点。

结论:二叉树的顺序结构,只适合存储完全二叉树。

二叉树的顺序存储结构描述如下:

#define MAXSIZE 20
typedef struct BiTNode {
ElemType data;             //数据域
int 1child, rchild;        //存放左、右孩子的数组下标
}BiTNode;                  //二叉树节点的类型BiTNode tree[MAXSIZE];
int n;                     //树中实际所含节点的个数
int root;                  //存放根节点的数组下标

二、链式存储

       二叉树的链式存储结构是指,用链表来表示一棵二叉树,即用链来指示元素的逻辑关系。 通常的方法是链表中每个结点由三个域组成数据域 (data)和左(lchild)、右(rchild)指针域左、右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址 。

二叉树的链式存储结构描述如下:

typedef struct BiTNode {
ElemType data;//数据域
struct BiTNode *1child, *rchild;//左、右孩子指针
}BiTNode, *BiTree;

       所以使用不同的存储结构时,实现二叉树操作的算法也会不同,因此要根据实际应用场合(二叉树的形态和需要进行的运算)来选择合适的存储结构。容易验证,在含有n个结点的二叉链表中,含有n+ 1个空链域

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

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

相关文章

双电机增程系统工作原理

问界M7的双电机增程系统是一项技术革新,它的核心在于高度集成的动力系统和先进的电机控制技术。 这种系统不仅提升了车辆的性能,还在保证高效能源利用的同时,为驾驶者带来了更舒适、更平稳的驾驶体验。 首先,让我们了解一下双电机…

Linux --- 高级IO

目录 1. 什么是IO 2. 阻塞的本质 3. 五种IO模型 3.1. 通过故事认识五种IO模型 3.2. 上述故事的总结 3.3. 具体的五种IO模型 3.3.1. 阻塞IO 3.3.2. 非阻塞轮询式IO 3.3.3. 信号驱动IO 3.3.4. 多路转接IO 3.3.5. 异步IO 4. 非阻塞IO 4.1. fcntl 系统调用 1. 什么是I…

2024最新软件测试【测试理论+ 数据库】面试题(内附答案)

一、测试理论 3.1 你们原来项目的测试流程是怎么样的? 我们的测试流程主要有三个阶段:需求了解分析、测试准备、测试执行。 1、需求了解分析阶段 我们的 SE 会把需求文档给我们自己先去了解一到两天这样,之后我们会有一个需求澄清会议, …

图像处理相关知识 —— 椒盐噪声

椒盐噪声是一种常见的图像噪声类型,它会在图像中随机地添加黑色(椒)和白色(盐)的像素点,使图像的质量降低。这种噪声模拟了在图像传感器中可能遇到的问题,例如损坏的像素或传输过程中的干扰。 椒…

每日两题 / 15. 三数之和 73. 矩阵置零(LeetCode热题100)

15. 三数之和 - 力扣(LeetCode) 先确定一个数t,对于剩下的两个数,要求两数之和为t的负数 三数之和就退化成了两数之和,两数之和可以用双指针 先排序,左右两个指针,指向的数之和大于目标值&…

llama_factory微调QWen1.5

GitHub - hiyouga/LLaMA-Factory: Unify Efficient Fine-Tuning of 100 LLMsUnify Efficient Fine-Tuning of 100 LLMs. Contribute to hiyouga/LLaMA-Factory development by creating an account on GitHub.https://github.com/hiyouga/LLaMA-FactoryQwen1.5 介绍 | QwenGITH…

考研数学|基础阶段做什么题,1800/1000/880/660?

基础阶段关键的不是做什么题,关键的是做题 不管你是做1800题还是做87-08年的老真题,任选一个都不会错,只要你静下心去做就行,不要朝三暮四,听别人说1800题好,就去做1800题,听别人说660题好&…

ubuntu系统CMAKE-3.29安装

下载包 https://cmake.org/download/下载后解压,运行./configure按照提示,输入:make 等待结束,然后输入:sudo make install 使用命令 :cmake --version

一篇文章详解深度学习正则化方法(L1、L2、Dropout正则化相关概念、定义、数学公式、Python代码实现)

目录 一、什么是正则化? 二、正则化的作用? 三、常见的正则化方法 四、详解L1正则化 五、详解L2正则化 六、详解Dropout方法 总结: 博主介绍:✌专注于前后端、机器学习、人工智能应用领域开发的优质创作者、秉着互联网精神开源贡…

【数据结构与算法】最大公约数与最小公倍数

最大公因数(英语:highest common factor,hcf)也称最大公约数(英语:greatest common divisor,gcd)是数学词汇,指能够整除多个非零整数的最大正整数。例如8和12的最大公因数…

2.4G漂移小车电子方案 酷得智能科技

漂移高速遥控车是一种专门设计用于执行高速漂移动作的遥控车模型。以下是一些关于漂移高速遥控车的功能介绍: 1、高速性能:漂移车通常配备有强力的电机和电池,以便在保持高速的同时进行漂移动作。 2、漂移能力:漂移车的轮胎和悬挂…

springboot同时支持jsp+vue页面启动

1、参考文档链接 参考上面文档边百度边改&#xff0c;现在可以了&#xff0c;分享下 2、Java项目目录结构 3、pom.xml内容 <?xml version"1.0" encoding"UTF-8"?><project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi&quo…