- 1、本文档共79页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第14讲:树及其应用
第14讲: 数据结构之
树;线形结构:
数据元素的逻辑位置之间呈线性关系,即每一个数据元素通常只有一个前驱(除第一个元素外)和一个后继(除最后一个元素外)。不管其存储方式(顺序和链式)如何.
栈、队列
非线形结构:
至少存在一个结点(数据元素)有多于一个前驱或后继的数据结构称为非线性结构。
???????? ??树、图
;一、树的概念
1、树的定义
树是一种常见的非线性的数据结构:树型结构。
空树(不含结点);非空树(至少一个结点);树的递归定义如下:
树是n(n=0)个结点的有限集,这个集合满足以下条件:
⑴有且仅有一个结点没有前驱(父亲结点),该结点称为树的根;
⑵除根外,其余的每个结点都有且仅有一个前驱;
⑶除根外,每一个结点都通过唯一的路径连到根上(否则有环)。这条路径由根开始,而未端就在该结点上,且除根以外,路径上的每一个结点都是前一个结点的后继(儿子结点);
由上述定义可知,树结构没有封闭的回路。
;2、结点的分类
结点一般分成三类
⑴根结点:没有父亲的结点。在树中有且仅有一个根结点。
⑵分支结点:除根结点外,有孩子的结点称为分支结点。
⑶叶结点:没有孩子的结点称为树叶。
根结点到每一个分支结点或叶结点的路径是唯一的。
从根A到结点M的唯一路径为ADHM。;3、树的度
????⑴结点的度:一个结点的子树数目称为该结点的度。
? ?⑵树的度:所有结点中最大的度称为该树的度(宽度)。;4、树的深度(高度)
树是分层次的。结点所在的层次是从根算起的。根结点在第一层,根的儿子在第二层,其余各层依次类推。图中的树共有4层。在树中,父结点在同一层的所有结点构成兄弟关系。
树中最大的层次称为树的深度,亦称高度。图中树的深度为4。;5、森林
所谓森林,是指若干棵互不相交的树的集合。如图去掉根结点A,其原来的三棵子树Tb,Tc,Td的集合{Tb,Tc,Td}就为森林,这三棵子树的具体形态如图(c)。;6、有序树和无序树
按照树中同层结点是否保持有序性,可将树分为有序树和无序树。
(1)如果树中同层结点从左而右排列,其次序不容互换,这样的树称为有序树;
(2)如果同层结点的次序任意,这样的树称为无序树。
;二、树的表示方法
树的表示方法一般有两种:
?????⑴自然界的树形表示法:用结点和边表示树,例如上图采用的就是自然界的树形表示法。树形表示法一般用于分析问题。;?⑵括号表示法:
先将根结点放入一对圆括号中,然后把它的子树按由左而右的顺序放入括号中,而对子树也采用同样方法处理:同层子树与它的根结点用圆括号括起来,同层子树之间用逗号隔开,最后用闭括号括起来。例如图可写成如下形式
(A(B(E(K,L),F),C(G),D(H(M),I,J)))
优点:易于保存;缺点:不直观.;树的存储结构一般有两种
1、静态的记录数组。所有结点存储在一个数组中,数组元素为记录类型,包括数据域和长度为n(n 为树的度)的数组,分别存储该结点的每一个儿子的下标
Const
n=树的度;
max=结点数的上限;
Type
node=record {结点类型}
data:datatype; {数据域}
child:array[1‥n] of integer; {指向各儿子的下标}
end;
treetype=array[1..max]of node;
Var tree:treetype; {树数组}
;1;2、动态的多重链表。由于树中结点可以有多个元素,所以可以用多重链表来描述比较方便。所谓多重链表,就是每个结点由数据域和n(n 为树的度)个指针域共n+1个域组成,其表示方法如下:
Const n=树的度;
Type
treetype=↑node; {结点类型}
node=record
data:datatype; {数据域}
您可能关注的文档
- 第11章(薄膜、劈尖、牛顿环)习题课.ppt
- 第11单元《种群群落》_浙江科技版.ppt
- 第11章_继电接触控制.ppt
- 第11章公共组织的变革与发展.ppt
- 第11章信息系统设计-翟小可.ppt
- 第11章_狭义相对论3.ppt
- 第11章 国际贸易的标的.ppt
- 第11章动机_副本_副本.ppt
- 第11章国际物流.ppt
- 第11章唐代统一多民族国家的繁荣.ppt
- 2025年综合类-中西医结合内科学-第十四单元肝系病症历年真题摘选带答案(5卷单选题100道).docx
- 2025年综合类-初级中学生物-生物学教师的备课历年真题摘选带答案(5卷单选题100道).docx
- 2025年综合类-临氢降凝装置操作工-初级临氢降凝操作工历年真题摘选带答案(5卷单选题100题).docx
- 2025年综合类-无线电装接工考试-初级无线电装接工历年真题摘选带答案(5卷单选题100题).docx
- 2025年住院医师规范培训(各省)-江苏住院医师急诊科历年参考题库含答案解析(5套共100道单选合辑.docx
- 2025年住院医师规范培训(各省)-上海住院医师精神科历年参考题库含答案解析(5套共100道单选题合.docx
- 2025年医药卫生考试-医院设备科考试历年参考题库含答案解析(5套100道单选题合辑).docx
- 2025年公路交通运输技能考试-吊车司机考试历年参考题库含答案解析(5套共100道单选合辑).docx
- 2025年综合类-护士护理考试-护士护理考试-急救护理学历年真题摘选带答案(5卷单选一百题).docx
- 2025年综合类-医学三基(护士)-人体解剖学历年真题摘选带答案(5卷100题).docx
最近下载
- 2025年内蒙古时事政治考试试卷带解析必考题.docx VIP
- 人教版数学三年级下册单元试卷【1-8合集,含答案】.pdf VIP
- 2025年内蒙古时事政治考试试卷带解析参考答案.docx VIP
- (答案)奥赛经典-奥林匹克数学中的几何问题---习题与讲解(第1-2章).pdf VIP
- 奥赛经典奥林匹克数学中的几何问题.pdf VIP
- 奥的斯电梯ACD4 原理图纸注释.pdf VIP
- 2025国家能源集团新疆哈密能源化工有限公司社会招聘(51人)笔试参考题库附答案解析.docx VIP
- 建设项目环境影响报告表.PDF VIP
- 呼吸科利用PDCA循环提高住院患者吸入剂使用正确率品管圈.pptx VIP
- 2024-2030年全球气动导弹弹射发射器(PMEL)行业现状、重点企业分析及项目可行性研究报告.docx
文档评论(0)