hafuman算法.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
hafuman算法

void Huffman_tree(Hnode ht[]) /*建哈夫曼树ht*/ { int i,j,n,p1,p2,w1,w2; printf(\n input n : ); scanf( %d,n); /*输入叶子结点个数*/ for(i=0; i2*n-1;++i)/*初始化ht*/ {ht[i].weight=0; ht[i].parent=ht[i].lchild=ht[i].rchild=-1;} printf(\n input %d weight : ,n);/*输入n个叶结点的权值*/ for(i=0;in;++i) scanf(%d,ht[i].weight); for(i=n; i2*n-1; ++i) /*每循环一次构造一个内部结点*/ { p1=p2=0; w1=w2= MAXVALUE; /*相关变量赋初值*/ for(j=0;j=i-1;j++) /*找两个最小权的子树结点*/ if(ht[j].parent0 ht[j].weightw1) { w2=w1;w1=ht[j].weight; p2=p1;p1=j;} else if(ht[j].parent0 ht[j].weightw2) { w2=ht[j].weight; p2=j; } /*将找出的两棵子树合并为一棵子树*/ ht[p1].parent=i; ht[p2].parent=i; ht[i].lchild=p1; ht[i].rchild=p2; ht[i].weight=ht[p1].weight+ht[p2].weight; } }哈夫曼树(Huffman树)是带权路径长度最小的二叉树。根据哈夫曼树的定义,一棵二叉树要使其带权路径长度最小,必须使权值越大的叶子结点越靠近根结点,而权值越小的叶子结点越远离根结点。哈夫曼依据这一特点提出了哈夫曼算法,其基本思想是:    初始化:由给定的n个权值{w1,w2,…,wn}构造n棵只有一个根结点的二叉树,从而得到一个二叉树集合F={T1,T2,…,Tn};    选取与合并:在F中选取根结点的权值最小的两棵二叉树分别作为左、右子树构造一棵新的二叉树,这棵新二叉树的根结点的权值为其左、右子树根结点权值之和;    删除与加入:在集合F中删除作为左、右子树的两棵二叉树,并将新建立的二叉树加入到集合F中;    重复、两步,当集合F中只剩下一棵二叉树时,这棵二叉树便是哈夫曼树。   通过上述Huffman树的构造过程,我们可以得到如下要点:    当有n个权值(相应的Huffman树中有n个叶子),共需合并n-1次;    每合并一次产生一个分支结点,经过n-1次合并后得到的Huffman树中共有2n-1个结点,其中有n-1个分支结点;    在Huffman树中只有度为0(叶子结点)和度为2(分支结点)的结点,不存在度为1的结点;    算法要求选取根结点权值最小的两棵二叉树作为左右子树构造一棵新的二叉树,但并没有要求哪一棵作左子树,哪一棵作右子树,所以左右子树的顺序是任意的;    对同一组权值可以构造出不同的huffman树,但是他们的带权路径长度相同。   在建立Huffman树的过程中有以下三种常见的错误:    在合并中不是选取根结点权值最小的两棵二叉树(包括已合并的和未合并的),而是选取未合并的根结点权值最小的一棵二叉树与已经合并的二叉树合并,如图5-10所示。    每次都是在未合并的二叉树中选取根结点的权值最小的两棵子树,如图5-11所示。    有时没有严格按照哈夫曼算法也构造出带权路径长度与哈夫曼树相同的二叉树,但那只是巧合,没有规律性,而没有规律性的解法不利于用计算机进行处理。 6.18高度为h的严格二叉树至少有多少个结点?至多有多少个结点?? 答: ??? 所谓严格二叉树是指该树中没有度数为1的分支结点的二叉树。 ??? 所以:高度为h的的严格二叉树至少有2h-1个结点;至多有2h-1个结点(即满二叉树)。 6.19 在什么样的情况下,等长编码是最优的前缀码? 答: ??? 在每个字符的使用概率相同的情况下,也即在哈夫曼树中每片叶子的权重相等的时候,等长编码是最优的前缀码。 6.20 下述编码哪一组不是前缀码? ??? {00,01,10,11},{0,1,00,11},{0,10,110,111} 答: ??? 第二组不是前缀码。因为0,1分别是00和11的前缀。(前缀码是指该编码集中的任一编码不是其他编码的前缀) 6.21 假设用于通信的电文由字符集{a,b,c,d,e,f,g,h}中的字母构成,这8个字母在电文中出现的概率分别为{0.07,0.19,0.02,0.06,0.32,0.03,0.21,0.10}. ? (1)为这8个字母设

文档评论(0)

xy88118 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档