数据结构(c语言版)树、二叉树 详细举例介绍

数据结构(c语言版)树、二叉树 详细举例介绍

ID:1449823

大小:2.37 MB

页数:138页

时间:2017-11-11

数据结构(c语言版)树、二叉树 详细举例介绍_第1页
数据结构(c语言版)树、二叉树 详细举例介绍_第2页
数据结构(c语言版)树、二叉树 详细举例介绍_第3页
数据结构(c语言版)树、二叉树 详细举例介绍_第4页
数据结构(c语言版)树、二叉树 详细举例介绍_第5页
资源描述:

《数据结构(c语言版)树、二叉树 详细举例介绍》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第六章树和二叉树6/9/202116.1树的类型定义6.2二叉树的类型定义6.3二叉树的存储结构6.4二叉树的遍历6.5线索二叉树6.6树和森林的表示方法6.7树和森林的遍历6.8哈夫曼树与哈夫曼编码目录6/9/202126.1树的类型定义6/9/20213数据对象D:D是具有相同特性的数据元素的集合。若D为空集,则称为空树;否则:(1)在D中存在唯一的称为根的数据元素root,(2)当n>1时,其余结点可分为m(m>0)个互不相交的有限集T1,T2,…,Tm,其中每一个子集本身又是一棵符合本定义的树,

2、称为根root的子树。数据关系R:ADTABCDEFGHIJKLM6/9/20214树的示例ABCDEFGHIJKLMABCDEFGHIJKLMABCDEFGHIJKLM6/9/20215基本操作:查找类插入类删除类6/9/20216Root(T)//求树的根结点Value(T,cur_e)//求当前结点的元素值Parent(T,cur_e)//求当前结点的双亲结点LeftChild(T,cur_e)//求当前结点的最左孩子RightSibling(T,cur_e)//求当前结点的右兄弟TreeEmpt

3、y(T)//判定树是否为空树TreeDepth(T)//求树的深度TraverseTree(T,Visit())//遍历查找类操作6/9/20217InitTree(&T)//初始化置空树CreateTree(&T,definition)//按定义构造树Assign(T,cur_e,value)//给当前结点赋值InsertChild(&T,&p,i,c)//将以c为根的树插入为结点p的第i棵子树插入类操作6/9/20218ClearTree(&T)//将树清空DestroyTree(&T)//销毁树的

4、结构DeleteChild(&T,&p,i)//删除结点p的第i棵子树删除类操作6/9/20219ABCDEFGHIJMKLA(B(E,F(K,L)),C(G),D(H,I,J(M)))T1T3T2树根树的广义表表示6/9/202110(1)有确定的根;(2)树根和子树根之间为有向关系。有向树有序树子树之间存在确定的次序关系。无序树子树之间不存在确定的次序关系。6/9/202111对比树型结构和线性结构的结构特点6/9/202112~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~线性结构树型

5、结构第一个数据元素(无前驱)根结点(无前驱)最后一个数据元素(无后继)多个叶子结点(无后继)其它数据元素(一个前驱、一个后继)其它数据元素(一个前驱、多个后继)6/9/202113基本术语6/9/202114结点:结点的度:树的度:叶子结点:分支结点:数据元素+若干指向子树的分支分支的个数树中所有结点的度的最大值度为零的结点度大于零的结点DHIJM6/9/202115(从根到结点的)路径:孩子结点、双亲结点、兄弟结点、堂兄弟祖先结点、子孙结点结点的层次:树的深度:由从根到该结点所经分支和结点构成ABCD

6、EFGHIJMKL假设根结点的层次为1,第l层的结点的子树根结点的层次为l+1树中叶子结点所在的最大层次6/9/202116任何一棵非空树是一个二元组Tree=(root,F)其中:root被称为根结点,F被称为子树森林森林:是m(m≥0)棵互不相交的树的集合ArootBCDEFGHIJMKLF6/9/2021176.2二叉树的类型定义6/9/202118二叉树或为空树;或是由一个根结点加上两棵分别称为左子树和右子树的、互不交的二叉树组成。ABCDEFGHK根结点左子树右子树6/9/202119NNNN

7、LRRL空树只含根结点右子树为空树左子树为空树左右子树均不为空树二叉树的五种基本形态:6/9/202120查找类插入类删除类二叉树的主要基本操作6/9/202121Root(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

8、,Visit());PostOrderTraverse(T,Visit());LevelOrderTraverse(T,Visit());查找类操作6/9/202122InitBiTree(&T);Assign(T,&e,value);CreateBiTree(&T,definition);InsertChild(T,p,LR,c);插入类操作6/9/202123ClearBiTree(&T);DestroyBiTree(&T);Delet

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

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

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