已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
左儿子右兄弟表示法树的左儿子右兄弟表示法又称为二叉树表示法或二叉链表表示法。每个结点除了data域外,还含有两个域,分别指向该结点的最左儿子和右邻兄弟。这种表示法常用二叉链表实现,因此又称为二叉链表表示法。但是实际应用中常用游标(静态链表)来代替链表,请参见表的游标实现。若用指针实现,其类型定义为:TypeTPosition=NodeType;NodeType=record Label:LabelType; Leftmost_Child,Right_Sibling:TPosition; end;TreeType=TPosition; 若用游标实现,其类型定义为:TypeTPosition=integer;NodeType=record Label:LabelType; Leftmost_Child,Right_Sibling:TPosition; end;CellspaceType=array 1.MaxNodeCount of NodeType;TreeType=TPosition;varCellspace:CellspaceType;Tree:TreeType; 此时树类型TreeType是整数类型,它指示树根在cellspace中的游标。例如图5(a)中树的左儿子右兄弟表示法的指针和游标实现分别如图5(b)和(c)所示。(a)(b)(c)图5 树的左儿子右兄弟表示法 用树的左儿子右兄弟表示法可以 直接实现树的大部分操作,只有在对树结点作Parent操作时需遍历树。如果要反复执行Parent操作,可在结点记录中再开辟一个指向父结点的指针域, 也可以利用最右儿子单元中的Right_Sibling作为指向父结点的指针(否则这里总是空指针)。当执行Parent(v)时,可以先通过 Right_Sibling逐步找出结点v的最右兄弟,再通过最右兄弟的Right_Sibling(父亲指针)找到父结点。这个结点就是结点v的父亲。 在这样的表示法下,求一个结点的父亲所需要的时间正比于该结点右边的兄弟个数。不过,这时每个记录中需要多用一位(bit)空间,用以标明该记录中的 right_sibling是指向右邻兄弟还是指向父亲。考虑到对于现在的计算机,内存已经不是很重要的限制因素了。我们下面就采取增加一个parent域的方案,以改进左儿子右兄弟表示法中Parent操作的效率。因此重新定义树的类型如下:若用指针实现,其类型定义为:TypeTPosition=NodeType;NodeType=record Label:LabelType; Parent,Leftmost_Child,Right_Sibling:TPosition; 增加一个Parent域 end;TreeType=TPosition;varTree:TreeType; 若用游标实现,其类型定义为:TypeTPosition=integer;NodeType=record Label:LabelType; Parent,Leftmost_Child,Right_Sibling:TPosition; 增加一个Parent域 end;CellspaceType=array 1.MaxNodeCount of NodeType;TreeType=TPosition;varCellspace:CellspaceType;Tree:TreeType; 下面我们只针对上面的指针实现方案实现树的ADT操作。对于指针实现的树,空结点表示空指针nil。对于浮标实现的树,可以类似地实现下面的操作。指针实现的左儿子右兄弟表示法实现的ADT树操作函数 Leftmost_Child(v,T)功能这是一个求最左儿子结点的函数。函数值为树T中结点v的最左儿子的位置。当v是叶结点时,函数值为nil,表示结点v没有儿子。实现Function Leftmost_Child(v:TPosition;var T:TreeType):TPosition;beginreturn(v.Leftmost_Child);end;说明返回v的最左儿子的位置指针。复杂性显然为O(1)。函数 Right_Sibling(v,T)功能这是一个求右邻兄弟的函数,函数值为树T中结点v的右邻兄弟。当v没有右邻兄弟时,函数值为nil。实现Function Right_Sibling(v:TPosition;var T:TreeType):TPosition;beginreturn(v.Right_Sibling);end;说明返回v的右邻兄弟的位置指针。复杂性显然为O(1)。函数 Parent(v,T)功能这是一个求父结点的函数,函数值为树T中结点v的父亲在结点表中的位置。当v是根结点时,函数值为nil,表示结点v没有父结点。实现Function Parent(v:TPosition;var T:TreeType):TPosition;beginreturn(v.Parent);end;说明返回v的父结点的位置指针。复杂性显然为O(1)。函数 Create(i,x,T1,T2,.,Ti)功能这是一族建树过程。对于每一个非负整数i,该函数生成一个新树T,T的根结点v的标号为x,并令v有i个儿子,这些儿子从左到右分别为树T1,T2,.,Ti的根。当i=0时,v既是树根,又是树叶。实现Function Create(i:integer;var x:LabelType;var T1,T2,.,Ti,T:TreeType);beginNew(T); 建T的根结点T.Label:=x;T.Parent:=nil;T.Right_Sibling:=nil;if i0 then begin T.Leftmost_Child:=T1; for k:=1 to i do begin Tk.Parent:=T; if ki then Tk.Right_Sibling:=Tk+1 else Tk.Right_Sibling:=nil; end;end;end;说明这个过程首先生成新树的根结点,其中存储的数据为x;然后对于每一个Tk,1ki,将Tk的根结点的父亲指向T,将Tk的根结点的右兄弟指向Tk+1(对于k=i的Tk其右兄弟为nil)。这
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年福建海峡银行龙岩分行诚聘英才备考题库参考答案详解
- 2025年中国科学院心理研究所认知与发展心理学研究室杜忆研究组招聘备考题库参考答案详解
- 圣诞节甜甜文案9篇
- 2026年少儿编程教育合作加盟合同
- 银联企业服务(上海)有限公司2026年度招聘备考题库及1套参考答案详解
- 国科大杭州高等研究院2025年9月批次公开招聘教学科研人员40人备考题库及1套完整答案详解
- 2025年北京协和医院变态(过敏)反应科合同制科研助理招聘备考题库及一套答案详解
- 甘肃电器科学研究院2025年度聘用制工作人员招聘备考题库附答案详解
- 2026年食品安全检测合同
- 2025年滁州市公安机关公开招聘警务辅助人员50人备考题库及1套完整答案详解
- 四川省达州市达川中学2025-2026学年八年级上学期第二次月考数学试题(无答案)
- 2025陕西西安市工会系统开招聘工会社会工作者61人历年题库带答案解析
- 江苏省南京市秦淮区2024-2025学年九年级上学期期末物理试题
- 债转股转让协议书
- 外卖平台2025年商家协议
- 2025年高职(铁道车辆技术)铁道车辆制动试题及答案
- (新教材)2026年人教版八年级下册数学 24.4 数据的分组 课件
- 2025陕西榆林市榆阳区部分区属国有企业招聘20人考试笔试模拟试题及答案解析
- 老年慢性病管理及康复护理
- 2025广西自然资源职业技术学院下半年招聘工作人员150人(公共基础知识)测试题带答案解析
- 智慧管廊云平台整体建设方案
评论
0/150
提交评论