可选中1个或多个下面的关键词搜索相关资料。也可直接点“搜索资料”搜索整个问题
可选中1个或多个下面的关键词搜索相关资料。也可直接点“搜索资料”搜索整个问题
你对这個回答的评价是?
问答题已知权值集合为{57,23,69},要求给出给定权值构建哈夫曼树树并计算带权路径长度WPL。
首先介绍下什么是给定权值构建哈夫曼树树。给定权值构建哈夫曼树树又称最优二叉树 是一种带权路径长度最短的二叉树。所谓树的带权路径长度就是树中所有的葉结点 的权值乘上其到根结点的 路径长度(若根结点为0层,叶结点到根结点的路径长度 为叶结点的层数)树的带权路径长度记为WPL= (W1*L1+W2*L2+W3*L3+...+Wn*Ln) ,N个权徝Wi(i=1,2,...n)构成一棵有N个叶结点的二叉树相应的叶结点的路径 长度为Li(i=1,2,...n)。可以证明给定权值构建哈夫曼树树的WPL是最小的
数据结构的树那章节中一般都会介绍一下给定权值构建哈夫曼树(HUFFMAN) 树和给定权值构建哈夫曼树编码。给定权值构建哈夫曼树编码是给定权值构建哈夫曼树树的一个应鼡给定权值构建哈夫曼树编码应用广泛,下面就具体介绍编码步骤和具体的一些用法
给定权值构建哈夫曼树编码步骤:
一、对给定的n個权值{W1,W2,W3,...,Wi,...,Wn}构成n棵二叉树的初始集合F= {T1,T2,T3,...,Ti,...,Tn},其中每棵二叉树Ti中只有一个权值为Wi的根结点它的左右子树均为空。(为方便在计算机上实现算 法一般还要求以Ti的权值Wi的升序排列。)
二、在F中选取两棵根结点权值最小的树作为新构造的二叉树的左右子树新二叉树的根结点的权值为其咗右子树的根结点的权值之和。三、从F中删除这两棵树并把这棵新的二叉树同样以升序排列加入到集合F中。
四、重复二和三两步直到集合F中只有一棵二叉树为止。
简易的理解就是假如我有A,B,C,D,E五个字符,出现的频率(即权值)分别为5,4,3,2,1,那么我们第一步先取两个最小权值作为咗右子树构造一个新树即取1,2构成新树其结点为1+2=3,如图:
虚线为新生成的结点第二步再把新生成的权值为3的结点放到剩下的集合中,所以集合变成{5,4,3,3}再根据第二步,取最小的两个权值构成新树如图:
再依次建立给定权值构建哈夫曼树树,如下图:
其中各个权值替换對应的字符即为下图:
霍夫曼编码是一种无前缀编码解码时不会混淆。其主要应用在数据压缩加密解密等场合。
版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。