数据结构与算法——第6章.pptVIP

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第6章 树和二叉树 本章主要内容 6.1 树的定义与基本操作 6.2 二叉树 6.3 树和森林 6.4 哈夫曼树与哈夫曼编码 6.1 树的定义与基本操作 6.1.1 树的定义与相关术语 6.1.2 树的抽象数据类型 6.1.1 树的定义与相关术语 树的定义可以有很多种方式,其中最自然的方式是递归定义。树(tree)T是n(n≥0)个点的有限集合,任何一个非空树都满足以下两个条件。 (1) 有且只有一个特定的称为根(root)的结点。 (2) 其余结点可分为m(m0)个互不相交的有限集合T1, T2, …, Tm,其中每个集合本身又是一个树,并称为树的子树(subtree)。 下面给出树结构中的一些基本术语。 度(degree):一个树结点中的子树个数称为该结点的度。 叶子(leaf):一棵树中,度为零的结点称为叶子。叶子结点有时又称为终端结点。 分支结点:与叶子结点相对应,分支结点是树中度为零的结点。分支结点有时又称为非终端结点。 孩子(child):树中某个结点的子树的根称为该结点的孩子。 双亲(parents):与孩子结点相对应。如果一个结点拥有孩子结点,则这个结点就称为孩子结点的双亲。双亲结点有时又称为父亲。 兄弟(brother):同一个双亲的孩子称为兄弟。 路径(path):若树中存在一个结点序列k1, k2, …, ki,使得ki是ki+1的双亲(1≤ij),则称该结点序列是从kl到kj的一条路径。路径的长度指路径所经过的边(即连接两个结点的线段)的数目,等于j-1。 祖先(ancestor):若树中结点k到ks存在一条路径,则称k是ks的祖先。 子孙(descendant):与祖先相对应,子孙结点就是路径中的ks结点。 层数(level):定义根结点的层数为1,即根结点在第1层(注意,有的书中规定根的层数为0)。其余结点的层数等于其双亲结点的层数加1。树结点中最大层数称为树的高度(height)或深度(depth)。 堂兄弟:如果两个结点的双亲在同一层,则称这两个结点互为堂兄弟。 有序树(orderedtree):若将树中每个结点的各子树看成是从左到右有次序的(即不能互换),则称该树为有序树。 无序树(unorderedTree):若树中每个结点的各子树是可以互换的,则称该树为无序树。 森林(forest):森林是m(m≥0)棵互不相交的树的集合。 树的逻辑特征可以进行以下描述。 (1)树中任一结点都可以有零个或多个直接后继(即孩子)结点,但至多只能有一个直接前趋结点,即双亲结点。 (2)树中只有根结点无前趋,它是开始结点;叶结点无后继,它们是终端结点。 (3)祖先与子孙的关系是父子关系的延伸,它定义了树中各结点之间的纵向次序。 (4)在有序树中,同一组兄弟结点从左到右有长幼之分。它定义了树中各结点之间的横向次序。 6.1.2 树的抽象数据类型 树的抽象数据类型定义如下: ADT Tree{ 数据对象: D是具有相同性质的数据元素的集合。 数据关系: 若D为空集,则称为空树;若D仅含有一个数据元素,则R为空集,否则R={H},H是如下的二元关系。 (1)在D中存在唯一的称为根的数据元素root,它在关系H中无前驱。 (2)在D-{root}≠,则存在D-{root}的一个划分D1,D2,…,Dm(m0),对任意j≠k,(1≤j,k≤m)有Di∩Dj=,且对任意的i(1≤i≤m),存在唯一的数据元素xi∈Di,root,xi∈H。 (3)对应于D-{root}的划分,H-{root,x1,…,root,xm}有唯一的一个划分H1,H2,…,Hm(m0),对任意i(1≤i≤m),Hi是Di上的二元关系,(Di,{H})是一棵符合本定义的树,称为根root的子树。 6.2 二 叉 树 6.2.1 二叉树的定义与基本操作 6.2.2 二叉树的性质 6.2.3 二叉树的存储结构 6.2.4 二叉树的遍历 6.2.5 线索化二叉树 6.2.1 二叉树的定义与基本操作 二叉树(binarytree)是n(n≥0)个结点的有限集,它或者是空集(n=0),或者由一个根结点及两棵互不相交的、分别称为这个根的左子树和右子树的二叉树组成。 二叉树存在两种特殊的情形:满二叉树和完全二叉树。 如果一棵树树根的深度为1,则深度为k且有2k-1个结点的二叉树称为满二叉树。 一棵满二叉树具有下面的两个特征。 (1)每一层上的结点数都达到最大值。即对给定的高度,满二叉树是所有二叉树中结点最多的二叉树。 (2)满二叉树中不存在度数为1的结点,每个分支结点均有两棵高度相同的子树,且叶子结点都在最下一层。 若一棵二叉树至

文档评论(0)

精华文档888 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档