数据结构第六章-树和二叉树课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《数据结构第六章-树和二叉树课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 第六 二叉 课件
- 资源描述:
-
1、6.1 树的定义和基本术语树的定义和基本术语6.3 遍历二叉树和线索二叉树遍历二叉树和线索二叉树6.4 树和森林树和森林6.6 哈夫曼树及其应用哈夫曼树及其应用6.1 树的定义和基本术语树的定义和基本术语ABCDEFGHIJMKLABCDEFGHIJMKL森林:森林:是m(m0)棵互不相交的树的集合BEFKLACGDHIJMABCDEFGHIJMKLA(B(E,F(K,L),C(G),D(H,I,J(M)T1T3T2树根例如例如:BEFKLABCDEFGHK根结点6.2 二叉树二叉树二叉树的五种基本形态:二叉树的五种基本形态:N空树空树只含根结点只含根结点NNNLRR右子树为空树右子树为空树L
2、左子树为空树左子树为空树左右子树左右子树均不为空均不为空树树查查 找找 插插 入入 删删 除除 性质性质 1:在二叉树的第 i 层上至多有2i-1 个结点。(i1)用归纳法证明用归纳法证明:归纳基归纳基:归纳假设:归纳假设:归纳证明:归纳证明:i=1 层时,只有一个根结点:2i-1=20=1;假设对所有的 j,1 j i,命题成立;二叉树上每个结点至多有两棵子树,则第 i 层的结点数=2i-2 2=2i-1。性质性质 2:深度为 k 的二叉树上至多含 2k-1 个结点(k1)。证明:证明:基于上一条性质,深度为 k 的二叉树上的结点数至多为 20+21+2k-1=2k-1。性质性质 3:对任何
3、一棵二叉树,若它含有n0 个叶子结点、n2 个度为 2 的结点,则必存在关系式:n0=n2+1。证明:证明:设设 二叉树上结点总数 n=n0+n1+n2又又 二叉树上分支总数 b=n1+2n2 而 b=n-1=n0+n1+n2-1由此,由此,n0=n2+1。123456789 10 11 12 13 14 15abcdefghij 性质性质 4:具有 n 个结点的完全二叉树的深度深度为 log2n +1。证明:证明:设设完全二叉树的深度为 k 则根据第二条性质得 2k-1 n 2k 即 k-1 log2 n n,则该结点无左孩子,否则,编号为 2i 的结点为其左孩子左孩子结点;(3)若 2i+
4、1n,则该结点无右孩子结点,否则,编号为2i+1 的结点为其右孩子右孩子结点。6.2.3 二叉树的存储结构二叉树的存储结构1.二叉树的顺序存储表示二叉树的顺序存储表示 例如例如:ABCDEF A B D C E F 0 1 2 3 4 5 6 7 8 9 10 11 12 1314013262 2、二叉树的链式存储表示、二叉树的链式存储表示ADEBCF rootlchild data rchild结点结构结点结构:lchild data rchild结点结构结点结构:ADEBCF root(2)三叉链表三叉链表parent lchild data rchild结点结构结点结构:parent l
5、child data rchild结点结构结点结构:6.3 遍历二叉树和线索二叉树遍历二叉树和线索二叉树 对对“二叉树二叉树”而言,可以而言,可以有三条搜索路径:有三条搜索路径:1先上后下先上后下的按层次遍历;2先左先左(子树)后右后右(子树)的遍历;3先右先右(子树)后左后左(子树)的遍历。二、先左后右的遍历算法二、先左后右的遍历算法先先(根)序的遍历算法中中(根)序的遍历算法后后(根)序的遍历算法 若二叉树为空树,则空操作;否则,(1)访问根结点;(2)先序遍历左子树;(3)先序遍历右子树。先(根)序的遍历算法:先(根)序的遍历算法:若二叉树为空树,则空操作;否则,(1)中序遍历左子树;(
6、2)访问根结点;(3)中序遍历右子树。中(根)序的遍历算法:中(根)序的遍历算法:若二叉树为空树,则空操作;否则,(1)后序遍历左子树;(2)后序遍历右子树;(3)访问根结点。后(根)序的遍历算法:后(根)序的遍历算法:三、算法的递归描述三、算法的递归描述四、中序遍历算法的非递归描述四、中序遍历算法的非递归描述五五、遍历算法的应用举例遍历算法的应用举例1、统计二叉树中叶子结点的个数、统计二叉树中叶子结点的个数 (先序遍历先序遍历)2、求二叉树的深度、求二叉树的深度(后序遍历后序遍历)3 3、建立二叉树、建立二叉树1、统计二叉树中叶子结点的个数、统计二叉树中叶子结点的个数算法基本思想算法基本思想
7、:先序(或中序或后序)遍历二叉树,在遍历过程中查找叶子结点,并计数。由此,需在遍历算法中增添一个需在遍历算法中增添一个“计数计数”的参数,的参数,并将算法中“访问结点”的操作改为:若是叶子,则计数器增若是叶子,则计数器增1 1。2、求二叉树的深度、求二叉树的深度(后序遍历后序遍历)算法基本思想算法基本思想:从二叉树深度的定义可知,二叉树的二叉树的深度应为其左、右子树深度的最大值加深度应为其左、右子树深度的最大值加1 1。由此,需先分别求得左、右子树的深度,需先分别求得左、右子树的深度,算法中“访问结点”的操作为:求得左、求得左、右子树深度的最大值,然后加右子树深度的最大值,然后加 1 1。首先
8、分析二叉树的深度二叉树的深度和它的左左、右子右子树深度树深度之间的关系。不同的定义方法相应有不同的不同的定义方法相应有不同的存储结构的建立算法存储结构的建立算法例如:ABCD以空白字符“”表示A(B(,C(,),D(,)空树空树只含一个根结点只含一个根结点的二叉树的二叉树A以字符串“A ”表示以下列字符串表示A B C D A BCD上页算法执行过程举例如下:上页算法执行过程举例如下:ATBCD 由先缀表示式建树由先缀表示式建树例如:已知表达式的先缀表示式 -+a b c/d e 由原表达式建树由原表达式建树例如:已知表达式(a+b)c d/e d/eabcde-+/特点特点:操作数为叶子叶子
9、结点 运算符为分支分支结点scanf(&ch);if(In(ch,字母集)建叶子结点;else 建根结点;递归建左子树;递归建右子树;a+b(a+b)c d/e d/ea+bc ab+abc+abc+(a+b)cabcde-+/基本操作基本操作:scanf(&ch);if(In(ch,字母集)建叶子结点;暂存;else if (In(ch,运算符集)和前一个运算符比较优先数;若当前的优先数“高”,则暂存;否则建子树;while(!Gettop(S,c)&(precede(c,ch)CrtSubtree(t,c);Pop(S,c);if(ch!=#)Push(S,ch);break;建叶子结点的
展开阅读全文