- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Chapter05树和二叉树-new
* ;知识回顾;第五章 树和二叉树;树是以分支关系定义的层次结构。
树结构在客观世界广泛存在:
在社会人文领域,人类社会构成、组织机构等也具有树结构关系。; * ;5.1 树的定义和基本术语;5.1.1 树的定义; * ;树(tree)是n (n≥0)个结点的有限集。在任意一棵非空树中:
(1)有且仅有一个特定的称为根的结点;
(2)当n1时,其余结点可分为m (m0)个互不相交的有限集T1,T2,…,Tm,其中每一个集合本身又是一棵树,并且称为根的子树。;A;树的表示法;图形表示法;嵌套集合表示法;( A ( B ( E ( K, L ), F ), C ( G ), D ( H ( M ), I, J ) )
约定:
根作为由子树森林组成的表的名字写在表的左边;凹入表示法;A;数据对象 D:; 基本操作:; Root(T) // 求树的根结点 ;InitTree(T) // 初始化置空树 ; ClearTree(T) // 将树清空 ;A;(1) 有确定的根;
(2) 树根和子树根之间为有向关系。;对比树型结构和线性结构的结构特点;~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~;5.1.2 基本术语;结点:;子孙:以某结点为根的子树中的任一结点。;有序树:子树之间存在确定的次序关系;A;任何一棵非空树是一个二元组
Tree = (root,F)
其中:root 被称为根结点
F 被称为子树森林;5.2 二叉树; 二叉树:或为空树,或是由一个根结点加上最多两棵分别称为左子树和右子树的、互不相交的二叉树组成。;二叉树的特点
(1)每个结点至多有二棵子树(即不存在度大于2的结点);
(2)二叉树的子树有左、右之分,且其次序不能任意颠倒。;二叉树的五种基本形态:; * ; 二叉树的主要基本操作:; Root(T); Value(T, e); Parent(T, e);
LeftChild(T, e); RightChild(T, e);
LeftSibling(T, e); RightSibling(T, e);
BiTreeEmpty(T); BiTreeDepth(T);
PreOrderTraverse(T, Visit());
InOrderTraverse(T, Visit());
PostOrderTraverse(T, Visit());
LevelOrderTraverse(T, Visit());; InitBiTree(T);
Assign(T, e, value);
CreateBiTree(T, definition);
InsertChild(T, p, LR, c);;ClearBiTree(T);
DestroyBiTree(T);
DeleteChild(T, p, LR);;二叉树的重要特性; 性质 1 :
在二叉树的第 i 层上至多??2i-1 个结点。 (i≥1);性质 2 : 深度为 k 的二叉树上至多含 2k-1 个结点(k≥1)。; 性质 3 : 对任何一棵二叉树,若它含有n0 个叶子结点、n2 个度为 2 的结点,则必存在关系式:n0 = n2+1。; * ; * ;两类特殊的二叉树:;1;完全二叉树特点:; * ;性质 4 :具有 n 个结点的完全二叉树的深度为 ? log2n? +1 。 ? x? 表示= x的最大整数。;证明:; * ;性质 5 :;1;问 题;思考题;知识回顾;二叉树的存储结构;存储方式:用一组地址连续的存储单元依次自上而下、自左至右存储完全二叉树上的结点元素,即将完全二叉树上编号为i的结点元素存储在一维数组中下标为i-1的分量中。;例如:;完全二叉树的数组表示 一般二叉树的数组表示;特点:
结点间关系蕴含在其存储位置中,浪费空间,适于存满二叉树和完全二叉树(在最坏情况下,深度为k且只有k个结点的单支树需要长度为2k-1的一维数组)
由于一般二叉树必须仿照完全二叉树那样存储,可能会浪费很多存
文档评论(0)