数据结构课件第五章树和二叉树.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Free template from 1、若一棵树中度为1的结点有n1个,度为2的结点有n2个,……,度为m的结点有nm个,它有多少个叶结点? 2、找出所有的二叉树,其结点在下列两种次序下恰好都以同样的顺序出现: (1)先根和中根 (2)先根和后根(3)中根和后根 3、设计一个算法,根据一个二叉树结点的先根序列和中根序列构造出该二叉树。假设二叉树是链接表示的,并且任意两个结点的info字段值都不同。 4、设计一个算法,将一个链接表示的二叉树中每个结点的左、右子女位置交换。 5、设计一个算法,按层次顺序输出二叉树中的所有结点,要求同一层上的结点从左到右输出。 6、设F是一个森林,B是与F对应的二叉树。试问,F中非叶结点的个数和B中右子树为空的结点的个数之间有什么数量关系? 【作业】 树的存储方法主要有哪些?举例说明具体存储结构。 线索:将二叉链表中的空指针域指向前驱结点和后继结点的指针被称为线索; 线索化:使二叉链表中结点的空链域存放其前驱或后继信息的过程称为线索化; 线索二叉树:加上线索的二叉树称为线索二叉树。 哈夫曼树的特点: 1. 权值越大的叶子结点越靠近根结点,而权值越小的叶子结点越远离根结点。 2. 只有度为0(叶子结点)和度为2(分支结点)的结点,不存在度为1的结点. 实习课内容: 用Huffman算法实现: w = {2,3,5,7,11,13,17,19, 23,29,31,37,41} 5.5 树、森林与二叉树的转换 2.保留双亲与第一孩子连线,删去与其他孩子的连线. A B C D E F G 树和二叉树之间的对应关系 1.兄弟加线. 3.顺时针转动,使之层次分明. 5.5 树、森林与二叉树的转换 树和二叉树之间的对应关系 2.保留双亲与第一孩子连线,删去与其他孩子的连线. 1.兄弟加线. A B C D E F G 3.顺时针转动,使之层次分明. 5.5 树、森林与二叉树的转换 树和二叉树之间的对应关系 2.保留双亲与第一孩子连线,删去与其他孩子的连线. 1.兄弟加线. G D A B E C F 树转换为二叉树 ⑴加线——树中所有相邻兄弟之间加一条连线。 ⑵去线——对树中的每个结点,只保留它与第一个孩子结点之间的连线,删去它与其它孩子结点之间的连线。 ⑶层次调整——以根结点为轴心,将树顺时针转动一定的角度,使之层次分明。 5.5 树、森林与二叉树的转换 森林转换为二叉树 ⑴ 将森林中的每棵树转换成二叉树; ⑵ 从第二棵二叉树开始,依次把后一棵二叉树的根结点作为前一棵二叉树根结点的右孩子,当所有二叉树连起来后,此时所得到的二叉树就是由森林转换得到的二叉树。 5.5 树、森林与二叉树的转换 二叉树转换为树或森林 ⑴ 加线——若某结点x是其双亲y的左孩子,则把结点x的右孩子、右孩子的右孩子、……,都与结点y用线连起来; ⑵ 去线——删去原二叉树中所有的双亲结点与右孩子结点的连线; ⑶ 层次调整——整理由⑴、⑵两步所得到的树或森林,使之层次分明。 5.5 树、森林与二叉树的转换 F H G E A I C D B F H G D C E B A I F E D C B A H G I 加线 去线 层次调整 I H G B C D A F E 5.5 树、森林与二叉树的转换 森林的遍历 森林有两种遍历方法: ⑴前序(根)遍历:前序遍历森林即为前序遍历森林中的每一棵树。 ⑵后序(根)遍历:后序遍历森林即为后序遍历森林中的每一棵树。 5.5 树、森林与二叉树的转换 相关概念 叶子结点的权值:对叶子结点赋予的一个有意义的数值量。 二叉树的带权路径长度:设二叉树具有n个带权值的叶子结点,从根结点到各个叶子结点的路径长度与相应叶子结点权值的乘积之和。 记为: WPL= 5.6 哈夫曼树及哈夫曼编码 ? = n k k k l w 1 第k个叶子的权值; 从根结点到第k个叶子的路径长度 哈夫曼树:给定一组具有确定权值的叶子结点,带权路径长度最小的二叉树。 例:给定4个叶子结点,其权值分别为{2,3,4,7},可以构造出形状不同的多个二叉树。 5.6 哈夫曼树及哈夫曼编码 WPL=32 WPL=41 WPL=30 2 3 4 7 2 3 4 7 7 4 2 3 5.6 哈夫曼树及哈夫曼编码 2 3 4 7 WPL=32 WPL=41 WPL=30 2 3 4 7 7 4 2 3 哈夫曼算法基本思想: ⑴ 初始化:由给定的n个权值{w1,w2,…,w

文档评论(0)

autohhh + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档