



免费预览已结束,剩余1页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
_二叉树的存储结构 二叉树是非线性结构,即每个数据结点至多只有一个前驱,但可以有多个后继。它可采用顺序存储结构和链式存储结构。1顺序存储结构二叉树的顺序存储,就是用一组连续的存储单元存放二叉树中的结点。因此,必须把二叉树的所有结点安排成为一个恰当的序列,结点在这个序列中的相互位置能反映出结点之间的逻辑关系,用编号的方法从树根起,自上层至下层,每层自左至右地给所有结点编号,缺点是有可能对存储空间造成极大的浪费,在最坏的情况下,一个深度为k且只有k个结点的右单支树需要2k-1个结点存储空间。依据二叉树的性质,完全二叉树和满二叉树采用顺序存储比较合适,树中结点的序号可以唯一地反映出结点之间的逻辑关系,这样既能够最大可能地节省存储空间,又可以利用数组元素的下标值确定结点在二叉树中的位置,以及结点之间的关系。图5-5(a)是一棵完全二叉树,图5-5(b)给出的图5-5(a)所示的完全二叉树的顺序存储结构。(a)一棵完全二叉树(b)顺序存储结构图5-5完全二叉树的顺序存储示意图对于一般的二叉树,如果仍按从上至下和从左到右的顺序将树中的结点顺序存储在一维数组中,则数组元素下标之间的关系不能够反映二叉树中结点之间的逻辑关系,只有增添一些并不存在的空结点,使之成为一棵完全二叉树的形式,然后再用一维数组顺序存储。如图5-6给出了一棵一般二叉树改造后的完全二叉树形态和其顺序存储状态示意图。显然,这种存储对于需增加许多空结点才能将一棵二叉树改造成为一棵完全二叉树的存储时,会造成空间的大量浪费,不宜用顺序存储结构。最坏的情况是右单支树,如图5-7所示,一棵深度为k的右单支树,只有k个结点,却需分配2k1个存储单元。(a)一棵二叉树(b)改造后的完全二叉树(c)改造后完全二叉树顺序存储状态图5-6一般二叉树及其顺序存储示意图(a)一棵右单支二叉树(b)改造后的右单支树对应的完全二叉树 (c)单支树改造后完全二叉树的顺序存储状态图5-7右单支二叉树及其顺序存储示意图结构5-1二叉树的顺序存储#define Maxsize 100 /假设一维数组最多存放100个元素typedef char Datatype; /假设二叉树元素的数据类型为字符typedef struct Datatype btMaxsize; int btnum; Btseq;2链式存储结构二叉树的链式存储结构是指,用链表来表示一棵二叉树,即用链来指示元素的逻辑关系。通常的方法是链表中每个结点由三个域组成,数据域和左右指针域,左右指针分别用来给出该结点左孩子和右孩子所在的链结点的存储地址。其结点结构为: 其中,data域存放某结点的数据信息;lchild与rchild分别存放指向左孩子和右孩子的指针,当左孩子或右孩子不存在时,相应指针域值为空(用符号或NULL表示)。利用这样的结点结构表示的二叉树的链式存储结构被称为二叉链表,如图5-8所示。 (a)一棵二叉树(b)二叉链表存储结构图5-8二叉树的二叉链表表示示意图为了方便访问某结点的双亲,还可以给链表结点增加一个双亲字段parent,用来指向其双亲结点。每个结点由四个域组成,其结点结构为:这种存储结构既便于查找孩子结点,又便于查找双亲结点;但是,相对于二叉链表存储结构而言,它增加了空间开销。利用这样的结点结构表示的二叉树的链式存储结构被称为三叉链表。图5-9给出了图5-8(a)所示的一棵二叉树的三叉链表表示。图5-9二叉树的三叉链表表示示意图尽管在二叉链表中无法由结点直接找到其双亲,但由于二叉链表结构灵活,操作方便,对于一般情况的二叉树,甚至比顺序存储结构还节省空间。因此,二叉链表是最常用的二叉树存储方式。结构5-2二叉树的链式存储#define datatype char /定义二叉树元素的数据类型为字符typedef struct node /定义结点由数据域,左右指针组成 Data
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 摩托部件基础知识培训课件
- 2025年河南省商丘市考研专业综合预测试题含答案
- 2024下半年漳州市漳浦县事业单位招聘考试《综合基础知识》试题(附答案)
- 摄影鉴赏课件
- 摄影技巧基础知识培训课件
- 微波技术基础试题及答案
- 2025版配套人民币借款合同
- 2025年春季部编版初中数学教学设计八年级下册第1课时 一次函数与一元一次方程、不等式
- 摄像头设置课件
- 2025合作伙伴:委托繁育品种合同大全
- 湖南省长沙市麓山国际实验学校2024-2025学年高一上学期第一次学情检测数学试卷2
- 园林绿化工(技师) 技能鉴定理论考试题及答案
- 活性炭改扩建项目环评报告书
- 神经病学-第十章-脑血管病的介入诊疗
- 贵州省大学生志愿服务西部计划志愿者招募笔试题库(含答案)
- 北京水务投资集团有限公司招聘笔试题库2024
- 丧葬服务行业的行业伦理与规范
- 完整版交管12123驾照学法减分复习真题A4版可打印
- PiCCO-监测技术操作管理
- ISO 22320-2018安全与韧性 应急管理 突发事件管理指南(中文版)
- 融资租赁租金及IRR收益测算表
评论
0/150
提交评论