- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
树 树的基本概念和表示 二叉树 遍历二叉树 哈夫曼树 4.1树的基本概念及表示 1.树的定义 树是由D(D≥0)个结点组成的有限集合。若D=0,称为空树;若D0,则: (1)有一个特定的称为根(root)的结点。它只有直接后继,但没有直接前驱; (2)除根结点以外的其它结点可以划分为m(m≥0)个互不相交的有限集合T0,T1,…,Tm-1,每个集合Ti(i=0,1,…,m-1)又是一棵树,称为根的子树,每棵子树的根结点有且仅有一个直接前驱,但可以有0个或多个直接后继。 由此可知,树的定义是一个递归的定义,即树的定义中又用到了树的概念。 树的结构参见图4-1。 在图4-1(c)中,树的根结点为A,该树还可以分为三个互不相交子集T0, T1,T2,具体请参见图4-2,其中T0={B,E,F,J,K,L},T1={C, G},T2={D,H,I,M},其中的T0,T1,T2都是树,称为图4-1(C) 中树的子树,而T0,T1,T2又可以分解成若干棵不相交子树。如T0可以 分解成T00,T01两个不相交子集,T00={E,J,K,L},T01={F},而 T00又可以分为三个不相交子集T000,T001,T002,其中,T000={J}, T001={K},T002={L}。 2.相关定义 1)结点 指树中的一个数据元素,一般用一个字母表示。具有同一个双亲的结点,称为兄弟结点。 节点的前驱称为父节点,节点的后继称为子节点。不再有后继的节点称为树叶 2)度 节点的度:一个结点包含子树的数目,称为该结点的度。 树的度:树中结点度的最大值称为树的度。 4)层数 根结点的层数为1,其它结点的层数为从根结点到该结点所经过的分支数目再加1。 3)树的高度(深度) 树中结点所处的最大层数称为树的高度,如空树的高度为0,只有一个根结点的树高度为1。 5)有序树 若一棵树中所有子树从左到右的排序是有顺序的,不能颠倒次序。称该树为有序树。 6)无序树 若一棵树中所有子树的次序无关紧要,则称为无序树。 7)森林(树林) 若干棵互不相交的树组成的集合为森林。一棵树可以看成是一个特殊的森林。 3.树的表示 树的二种表示方法 1)树形图(如图4—1所示) 2)广义表 按照“根——左——右”的规律将树中的节点分别放入括号之中。具体做法 是:在一对括号中先写根节点,在根节点后面的一对括号内按从左到右 的顺序写各个子树,同层子树用逗号隔开。对图4-1(c)的树结构,广 义表表示法可表示为: (A(B(E(J,K,L),F),C(G),D(H(M),I))) 练一练 如下图所示:用广义表表示,并指出它的度和深度 (A(B(E,F(K,L)),C(G),D(H,I,J(M)))) 深度:4 度:3 4.2二叉树 和树结构定义类似,二叉树的定义也可以递归形式给出: 二叉树是D(D≥0)个结点的有限集,它或者是空集(D=0),或者由一个根结点及两棵不相交的左子树和右子树组成。 二叉树的特点是每个结点最多有两个孩子,或者说,在二叉树中,不存在度大于2的结点,并且二叉树是有序树(树为无序树),其子树的顺序不能颠倒,因此,二叉树有五种不同的形态,参见图4-5 。 1)二叉树的定义 4.2.2 二叉树的性质 性质1 若二叉树的层数从1开始,则二叉树的第k层结点数,最多为2k-1个(k0)。 可以用数学归纳法证明之。 性质2 深度(高度)为k的二叉树最大结点数为2k-1(k0)。 证明: 深度为k的二叉树,若要求结点数最多,则必须每一层的结点数都为最多,由性质1可知,最大结点数应为每一层最大结点数之和。既为 20+21+…+2k-1=2k-1。 性质3 对任意一棵二叉树,如果叶子结点个数为D0,度为2的结点个数为D2,则有D0=D2+1。 证明:设二叉树中度为1的结点个数为D1,根据二叉树的定义可知,该二叉树的结点数D=D0+D1+D2。又因为在二叉树中,度为0的结点没有孩子,度为1的结点有1 个孩子,度为2的结点有2个结孩子,故该二叉树的孩子结点数为 D0*0+D1*1+D2*2 ,而一棵二叉树中,除根结点外所有都为孩子 结点,故该二叉树的结点数应为孩子结点数加1即:D=D0*0+D1*1+D2*2+1因此,有 D=D0+D1+D2=D0*0+D1*1+D2*2+1,最后得到D0=D2+1。 满二叉树 深度为k具有2k-1个结点的二叉树,称为满二叉树。 从上面满二叉树定义可知,必须是二叉树的每一层上的结点数都达到最大,否则就不是满二叉树。 完全二叉树 如果一棵具有D个结点的深度为k的二叉树,它的每一个结点都与深度为k的满二叉树中编号为1~ D的结点一一对应,则称这棵二叉树为完全二叉树。 从完全二叉树定义可知,结点的排列顺序
您可能关注的文档
最近下载
- 电磁感应中的图像类问题-备战2021年高考物理考点专项突破题集(原卷版).doc VIP
- SAE-ARP4754A民用飞机和系统开发指南翻译文稿.pdf
- 2025年公共营养师维生素C与维生素E、类胡萝卜素的协同抗氧化网络专题试卷及解析.pdf VIP
- 电力电子技术阮新波习题答案.pdf VIP
- “挑战杯”创业计划竞赛培训PPT(共74页).ppt VIP
- 2025中国Data&AI数据基础设施白皮书-甲子光年.pdf VIP
- 北京西城区2022-2023年三年级上学期期末数学试卷.pdf VIP
- XX银行A分行业务人员培训需求分析.pdf VIP
- 国企制服规范:机关工作服管理指南.docx VIP
- 莫言艺术风格.doc VIP
原创力文档


文档评论(0)