数据结构第六章树和二叉树

数据结构第六章树和二叉树

ID:37401496

大小:252.10 KB

页数:62页

时间:2019-05-12

数据结构第六章树和二叉树_第1页
数据结构第六章树和二叉树_第2页
数据结构第六章树和二叉树_第3页
数据结构第六章树和二叉树_第4页
数据结构第六章树和二叉树_第5页
资源描述:

《数据结构第六章树和二叉树》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第六章树和二叉树第一节树的类型定义A为“根”T1、T2和T3都是一棵树,称为A的子树。称根和子树根之间的连线为“分支”结点分支的个数定义为“结点的度”,如结点B的度为2,D的度为3。树中所有结点度的最大值定义为“树的度”。称度为零的结点为“叶子”或“终端结点”所有度不为零的结点被称作"分支结点"基本定义森林为m(m≥0)棵互不相交的树的集合。树的深度定义为树中叶子结点所在最大层次数。称根结点为子树根的"双亲"。称子树根为根结点的"孩子“根的所有子树根互为“兄弟”。有序树、无序树如果树中每棵子树从左向右的排列拥有一定的顺序,不得互

2、换,则称为有序树,否则称为无序树。树的抽象数据类型:ADTTree{数据对象:D是具有相同特性的数据元素的集合。数据关系:   若D为空集,则称为空树;   若D中仅含一个数据元素,则关系R为空集;   否则R={H},(1)在D中存在唯一的称为根的数据元素root,它在关系H下无前驱;(2)当n>1时,其余数据元素可分为m(m>0)个互不相交的(非空)有限集T1,T2,…,Tm,其中每一个子集本身又是一棵符合本定义的树,称为根root的子树,每一棵子树的根xi都是根root的后继,即H,i=1,2,…,m。基

3、本操作:{结构初始化}InitTree(&T);操作结果:构造空树T。CreateTree(&T,definition);初始条件:definition给出树T的定义。    操作结果:按definition构造树T。{销毁结构}DestroyTree(&T);初始条件:树T存在。    操作结果:销毁树T。{引用型操作}TreeEmpty(T);初始条件:树T存在。    操作结果:若T为空树,则返回TRUE,否则返回FALSE。TreeDepth(T);初始条件:树T存在。    操作结果:返回T的深度。Root(T);初始

4、条件:树T存在。    操作结果:返回T的根。Value(T,cur_e);初始条件:树T存在,cur_e是T中某个结点。    操作结果:返回cur_e的值。Parent(T,cur_e);初始条件:树T存在,cur_e是T中某个结点。   操作结果:若cur_e是T的非根结点,则返回它的双亲,否则返回"空"。LeftChild(T,cur_e);初始条件:树T存在,cur_e是T中某个结点。   操作结果:若cur_e是T的非叶子结点,则返回它的最左孩子,否则返回"空"。RightSibling(T,cur_e);初始条件:

5、树T存在,cur_e是T中某个结点。   操作结果:若cur_e有右兄弟,则返回它的右兄弟,否则返回"空"。TraverseTree(T,visit());初始条件:树T存在,visit是对结点操作的应用函数。   操作结果:按某种次序对T的每个结点调用函数visit()一次且至多一次。一旦visit()失败,则操作失败。{加工型操作}Assign(T,cur_e,value);初始条件:树T存在,cur_e是T中某个结点。    操作结果:结点cur_e赋值为value。ClearTree(&T);初始条件:树T存在。    

6、操作结果:将树T清为空树。InsertChild(&T,&p,i,c);初始条件:树T存在,p指向T中某个结点,1≤i≤p所指结点的度+1,非空树c与T不相交。    操作结果:插入c为T中p所指结点的第i棵子树。DeleteChild(&T,&p,i);初始条件:树T存在,p指向T中某个结点,1≤i≤p指结点的度。    操作结果:删除T中p所指结点的第i棵子树。}ADTTree树和线性结构对照:第二节二叉树类型定义:二叉树是另一种树形结构。它与树形结构的区别是:(1)每个结点最多有两棵子树;(2)子树有左右之分。二叉树也可以

7、用递归的形式定义。即:二叉树是n(n≥0)个结点的有限集合。当n=0时,称为空二叉树;当n>0时,有且仅有一个结点为二叉树的根,其余结点被分成两个互不相交的子集,一个作为左子集,另一个作为右子集,每个子集又是一个二叉树。二叉树的5种形态:ø(a)(b)(c)(d)(e)6.2.1二叉树的类型定义ADTBinaryTree{数据对象:D是具有相同特性的数据元素的集合。数据关系:    若D为空集,称BinaryTree为空二叉树;    否则关系R={H}:(1)在D中存在唯一的称为根的数据元素root,它在关系H下无前驱;(2)

8、D中其余元素必可分为两个互不相交的子集L和R,每一个子集都是一棵符合本定义的二叉树,并分别为root的左子树和右子树。如果左子树L不空,则必存在一个根结点,它是root的"左后继"(∈H),如果右子树R不空,则必存在一个根结点为root的"右后继"

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。