- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第5章专题6哈夫曼树
Free template from 哈夫曼树的特点: 1. 权值越大的叶子结点越靠近根结点,而权值越小的叶子结点越远离根结点。 2. 只有度为0(叶子结点)和度为2(分支结点)的结点,不存在度为1的结点. 1. 编写非递归算法,求二叉树中叶子结点的个数。 2. 已知某字符串S为“abcdeacedaeadcedabadadaead” ,对该字符串用[0,1]进行前缀编码,问该字符串的编码至少有多少位。 数据结构(C++版)第2版 清华大学出版社 专题6:哈夫曼树和哈夫曼编码 1 2 哈夫曼树的基本概念 哈夫曼算法 3 哈夫曼编码 相关概念 叶子结点的权值:对叶子结点赋予的一个有意义的数值量。 二叉树的带权路径长度:设二叉树具有n个带权值的叶子结点,从根结点到各个叶子结点的路径长度与相应叶子结点权值的乘积之和。 记为: WPL= 5.7 哈夫曼树及哈夫曼编码 ? = n k k k l w 1 第k个叶子的权值; 从根结点到第k个叶子的路径长度 哈夫曼树:给定一组具有确定权值的叶子结点,带权路径长度最小的二叉树。 例:给定4个叶子结点,其权值分别为{2,3,4,7},可以构造出形状不同的多个二叉树。 5.7 哈夫曼树及哈夫曼编码 WPL=32 WPL=41 WPL=30 2 3 4 7 2 3 4 7 7 4 2 3 5.7 哈夫曼树及哈夫曼编码 2 3 4 7 WPL=32 WPL=41 WPL=30 2 3 4 7 7 4 2 3 ⑴ 初始化:由给定的n个权值{w1,w2,…,wn}构造n棵只有一个根结点的二叉树,从而得到一个二叉树集合F={T1,T2,…,Tn}; ⑵ 选取与合并:在F中选取根结点的权值最小的两棵二叉树分别作为左、右子树构造一棵新的二叉树,这棵新二叉树的根结点的权值为其左、右子树根结点的权值之和; ⑶ 删除与加入:在F中删除作为左、右子树的两棵二叉树,并将新建立的二叉树加入到F中; ⑷ 重复⑵、⑶两步,当集合F中只剩下一棵二叉树时,这棵二叉树便是哈夫曼树。 5.7 哈夫曼树及哈夫曼编码 哈夫曼算法——基本思想 第1步:初始化 W={2,4,5 ,3} 哈夫曼树的构造过程 5.7 哈夫曼树及哈夫曼编码 3 5 2 4 第2步:选取与合并 3 2 5 第3步:删除与加入 5 4 3 2 5 W={2,4,5 ,3} 哈夫曼树的构造过程 5.7 哈夫曼树及哈夫曼编码 重复第2步 5 4 3 2 5 5 4 9 重复第3步 5 5 4 9 3 2 W={2,3,4,5} 哈夫曼树的构造过程 5.7 哈夫曼树及哈夫曼编码 重复第2步 重复第3步 5 5 4 9 3 2 5 5 4 9 3 2 14 哈夫曼算法——存储结构 1. 设置一个数组huffTree[2n-1]保存哈夫曼树中各点的信息,数组元素的结点结构 。 weight lchild rchild parent 其中:weight:权值域,保存该结点的权值; lchild:指针域,结点的左孩子结点在数组中的下标; rchild:指针域,结点的右孩子结点在数组中的下标; parent:指针域,该结点的双亲结点在数组中的下标。 struct element { int weight; int lchild, rchild, parent; }; 5.7 哈夫曼树及哈夫曼编码 数组huffTree初始化,所有元素结点的双亲、左 右孩子都置为-1; 2. 数组huffTree的前n个元素的权值置给定值w[n]; 3. 进行n-1次合并 3.1 在二叉树集合中选取两个权值最小的根结点, 其下标分别为i1, i2; 3.2 将二叉树i1、i2合并为一棵新的二叉树k; 5.7 哈夫曼树及哈夫曼编码 哈夫曼算法——伪代码 weight parent lchild rchild -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 0 1 2 3 4 5 6 初
原创力文档


文档评论(0)