- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第6章 树和二叉树 学习目标: 1)理解树的定义和基本术语,了解树的表示方法; 2)掌握二叉树的定义、存储结构,熟练掌握二叉树的遍历,了解线索二叉树; 3)熟练掌握哈夫曼树的定义和应用; 4)理解树和森林的关系,掌握森林和二叉树的转换、遍历; 6.1.1 树的定义 树(tree)是由n(n≥0)个结点组成的有限集合。若n=0,称为空树;若n0,则称为非空树。 在一棵非空树中,具有如下特征: (1)有一个特定的称为根(root)的结点。它只有直接后继,但没有直接前驱; (2)除根结点以外的其他结点可以划分为m(m≥0)个互不相交的有限集合T0,T1,…,Tm-1,每个集合Ti(i=0,1,…,m-1)又是一棵树,称为根的子树,每棵子树的根结点有且仅有一个直接前驱,但可以有0个或多个直接后继 树还可以采用下面的逻辑结构描述: tree =(k,R) k={ki∣1≤i≤n;n≥0,ki?elemtype};R={r} 其中,n为树中结点个数,若 n=0,则为一棵空树, n 0时称为一棵非空树,而关系 r 应满足下列条件: (1)有且仅有一个结点没有前驱,称该结点为树根; (2)除根结点以外,其余每个结点有且仅有一个直接前驱; (3)树中每个结点可以有多个直接后继(孩子结点)。 6.1.2 树的表示 1.树形结构表示法 2.凹入法表示法 3.嵌套集合表示法 4. 广义表表示法 6.1.3 树的基本术语 结点:包含一个数据元素及若干指向其他结点的分支信息,在树的表示方法中以一个圆圈或短线表示。 结点的度:一个结点的子树个数称为此结点的度,例如:图6-1(c)中结点A的度为3,结点G的度为0。 叶子结点:度为0的结点,即无后继的结点,也称为终端结点,图6-1(c)中结点G,F,K,L,J,I,M。 分支结点:度不为0的结点,也称为非终端结点,图6-1(c)中除结点G,F,K,L,J,I,M之外的所有结点。 孩子结点:一个结点的直接后继称为该结点的孩子结点。在图6-1(c)中,结点 B、C、D是结点A的孩子。 双亲结点:一个结点的直接前驱称为该结点的双亲结点。在图6-1(c)中,结点A 是结点B、C、D的双亲。 兄弟结点:同一双亲结点的孩子结点之间互称兄弟结点。在图6-1(c)中,结点K、L、 J互为兄弟结点。 祖先结点:一个结点的祖先结点是指从根结点到该结点的路径上的所有结点。在图6-1(c)中,结点K的祖先是A、B、E。 子孙结点:一个结点的直接后继和间接后继称为该结点的子孙结点。在图6-1(c)中,结点B的子孙是F、E、K、L、J。 树的度: 树中所有结点的度的最大值,图6-1(c)中树的度为3。 结点的层次:从根结点开始定义,根结点的层次为1,根的直接后继的层次为2,依此类推。 树的高度(深度): 树中所有结点的层次的最大值,图6-1(c)中树的高度为4。 有序树:在树T中,如果各子树Ti之间是有先后次序的,则称为有序树。 森林: m(m≥0)棵互不相交的树的集合。将一棵非空树的根结点删去,树就变成一个森林;反之,给森林增加一个统一的根结点,森林就变成一棵树。 6.2.1 二叉树的定义 二叉树的定义与基本形态 二叉树是n(n≥0)个结点的有限集,它或者是空集(n=0),或者由一个根结点及两棵不相交的左子树和右子树组成。 二叉树的特点是每个结点最多有两个孩子,或者说,在二叉树中,不存在度大于2的结点,并且二叉树是有序树(一般树为无序树),其子树的顺序不能颠倒。 二叉树可以有以下五种不同的基本形态 2. 二叉树的基本操作 (1) Initiate(bt):将bt初始化为空二叉树。 (2) Create(bt):创建一棵非空二叉树bt。 (3) Destory(bt):销毁二叉树bt。 (4) Empty(bt):若bt为空,则返回TRUE,否则返回FALSE。 (5) Root(bt):求二叉树bt的根结点。若bt为空二叉树, 则函数返回“空”。 (6) Parent(bt,x):求双亲函数。求二叉树bt中结点x的双亲结点。若结点x是二叉树的根结点或二叉树bt中无结点x,则返回“空”。 (7) LeftChild(bt,x):求左孩子。若结点x为叶子结点或x不在bt中,则返回“空”。 (8) RightChild(bt,x):求右孩子。 若结点x为叶子结点或x不在bt中,则返回“空”。 (
文档评论(0)