哈夫曼树的构造

作者&投稿:战月 (若有异议请与网页底部的电邮联系)
哈夫曼树的构造,关键字如图~

哈夫曼树构造规则:
假设有n个权值,则构造出的哈夫曼树有n个叶子结点。 n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为:
(1) 将w1、w2、…,wn看成是有n 棵树的森林(每棵树仅有一个结点);
(2) 在森林中选出两个根结点的权值最小的树合并,作为一棵新树的左、右子树,且新树的根结点权值为其左、右子树根结点权值之和;
(3)从森林中删除选取的两棵树,并将新树加入森林;
(4)重复(2)、(3)步,直到森林中只剩一棵树为止
根据上述步骤得到的哈夫曼数是
(100)
/ \
(43) 57
/ \ / \
(20) 23 (27) 30
/ \ / \
9 (11) 11 16
/ \
4 7

来自百度百科:哈夫曼树构造方法:
假设有n个权值,则构造出的哈夫曼树有n个叶子结点。 n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为:
(1) 将w1、w2、…,wn看成是有n 棵树的森林(每棵树仅有一个结点);
(2) 在森林中选出两个根结点的权值最小的树合并,作为一棵新树的左、右子树,且新树的根结点权值为其左、右子树根结点权值之和;
(3)从森林中删除选取的两棵树,并将新树加入森林;
(4)重复(2)、(3)步,直到森林中只剩一棵树为止,该树即为所求得的哈夫曼树。

简单的说,就是选择两个权值最小的节点,构造一棵树,树的根权值是两个权值最小的节点之和,将新的权值节点放回序列,继续按照上述方法构造,直到只有一棵树为止,这样的树其WPL最小。

第一步:排序 2 4 5 9
第二步:挑出2个最小的 2 4 为叶子构造出
6
2 4
第三步:判断 6 不大于 5或9(剩余叶子中最小的2个)=》 同方向生长,得出:
11
6 5
2 4
第四步:继续生长
20
11 9
6 5
2 4
权值为 2*3+4*3+5*2+9*1=37
也可以20+11+6=37

例题:6、13、18、30、7、16
排序 6 7 13 16 18 30
13
6 7
26 26大于16或18 =》分支生长
13 13
6 7
26 34
13 13 16 18
6 7
此时最小的2个数为 26 30 得出
56 34
26 30 16 18
13 13
6 7
最后得出 90
56 34
26 30 16 18
13 13
6 7 权值 219
90+56+26+13+34 or 6*4+7*4+13*3+30*2+16*2+18*2

前序遍历:ABDECFG
中序遍历:DBEAFCG
后序遍历:DEBFGCA

前序遍历:1 2 4 3 5 7 6
中序遍历:2 4 1 5 7 3 6
后序遍历:4 2 7 5 6 3 1

做类似的题目,你可以先由两个遍历画出二叉树。通过形象的二叉树来写出另一个遍历,写的方法如上(递归)。画出二叉树的方法如下:

已知一棵二叉树的前序序列和中序序列,构造该二叉树的过程如下:
1. 根据前序序列的第一个元素建立根结点;
2. 在中序序列中找到该元素,确定根结点的左右子树的中序序列;
3. 在前序序列中确定左右子树的前序序列;
4. 由左子树的前序序列和中序序列建立左子树;
5. 由右子树的前序序列和中序序列建立右子树。

已知一棵二叉树的后序序列和中序序列,构造该二叉树的过程如下:
1. 根据后序序列的最后一个元素建立根结点;
2. 在中序序列中找到该元素,确定根结点的左右子树的中序序列;
3. 在后序序列中确定左右子树的后序序列;
4. 由左子树的后序序列和中序序列建立左子树;
5. 由右子树的后序序列和中序序列建立右子树。

第一步排序
2 3 6 7 10 19 21 32
构图如下 谢谢提醒 我粗心了……

字符版 复制到记事本里看
********o**********
*******/*\*********
*****o*****o*******
****/*\***/*\******
***19*21**o**32****
*********/*\*******
********o***o******
*******/*\*/*\*****
*******o*6*7*10****
******/*\**********
******2*3**********

顾名思义,这可不是一棵真正的树,实际上是类似树木的根系,金字塔那样的模型,这的模型可有用了,能帮助我们轻松地了解,很弄懂一些相关的问题,很有创意,很有价值


怎么构建哈夫曼树
问题一:如何建立哈夫曼树 哈夫曼树: 82 \/ \\ 33 49 \/ \\ \/ \\ 16 17 20 29 \/ \\ \/ \\ 9 11 14 15 \/ \\ 5 6 \/ \\ 2 3 图片没法上传 问题二:哈夫曼树的构造 10分 第一步:排序 2 4 5 9 第二步:挑出2个最小的 2 4 为叶子构造出 6 2 4 第三步:判断 6 不大于 5或9...

哈夫曼树的建立
树的带权路径长度记为WPL=(W1*L1+W2*L2+W3*L3+...+Wn*Ln),N个权值Wi(i=1,2,...n)构成一棵有N个叶结点的二叉树,相应的叶结点的路径长度为Li(i=1,2,...n)。可以证明哈夫曼树的WPL是最小的。哈夫曼在上世纪五十年代初就提出这种编码时,根据字符出现的概率来构造平均长度最短的编码...

初步认识哈夫曼树
哈夫曼树的特点 –权值大的结点到根结点的路径长度短;–权值小的结点到根结点的路径长度长。Ø哈夫曼编码树中没有度为1的结点;Ø若给定n个权值(n个叶子结点),则哈夫曼树的总结点数为 2n-1;Ø哈夫曼树的高度不超过n。哈夫曼数的构造算法:哈夫曼编码:v前缀编码:任一字符的...

哈夫曼树一定是完全二叉树吗
构造哈夫曼树的思想是每次选k个权重最小的元素来合成一个新的元素,该元素权重为k个元素权重之和。但是当k大于2时,按照这个步骤做下去可能到最后剩下的元素少于k个。解决这个问题的办法是假设已经有了一棵哈夫曼树(且为一棵满k叉树),则可以计算出其叶节点数目为(k-1)nk+1,式子中的nk表示子...

哈夫曼树的特点
哈夫曼树的任意非叶节点的左右子树交换后仍是哈夫曼树;n个叶子结点的哈夫曼树共有2n-1个结点;对同一组权值{w1 ,w2 , …… , wn},存在不同构的两棵哈夫曼树 1、什么是哈夫曼树:哈夫曼树也称最优二叉树,含有n个带权叶子结点带权路径长度最小的二叉树 2、哈夫曼树的构造思路 将n个结点...

哈夫曼树的构造
第一步:排序 2 4 5 9 第二步:挑出2个最小的 2 4 为叶子构造出 6 2 4 第三步:判断 6 不大于 5或9(剩余叶子中最小的2个)=》 同方向生长,得出:11 6 5 2 4 第四步:继续生长 20 11 9 6 5 2 4 权值为 2*3+4*3+5*2+9*1=37 也可以20+11+...

n个叶子结点的哈夫曼树共有几个结点
n个叶子结点的哈夫曼树共有2n-1个结点。给定N个权值作为N个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近。

哈夫曼树的构造步骤哈夫曼树的构造
关于哈夫曼树的构造步骤,哈夫曼树的构造这个很多人还不知道,今天来为大家解答以上的问题,现在让我们一起来看看吧!1、第一步:排序 2 4 5 9第二步:挑出2个最小的 2 4 为叶子构造出 62 4第三步:判断 6 不大于 5或9(剩余叶子中最小的2个)=》 同方向生长。2、得出: ...

哈夫曼树的结点个数不能是偶数。
关于哈夫曼树的结点个数不能是偶数回答如下:1.哈夫曼树介绍 给定N个权值作为N个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近。在计算机数据处理中,哈夫曼编码...

哈夫曼树的构造算法
* Date: 2011.04.16 * Author: Jeffrey Hill+Jezze(解码部分) * 在 Win-TC 下测试通过 * 实现过程:着先通过 HuffmanTree() 函数构造哈夫曼树,然后在主函数 main()中 * 自底向上开始(也就是从数组序号为零的结点开始)向上层层判断,若在 * 父结点左侧,则置码为 0,若在右侧,...

绥德县15138852703: 怎样构造合适的哈夫曼树? -
希容川贝: 来自百度百科:哈夫曼树构造方法: 假设有n个权值,则构造出的哈夫曼树有n个叶子结点. n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为: (1) 将w1、w2、…,wn看成是有n 棵树的森林(每棵树仅有一个结点); (2) 在森...

绥德县15138852703: 哈夫曼树的构成原理? -
希容川贝: #include#include #define MAXSIZE 30/*自定义哈夫曼的最大个数*/ typedef struct { int weight;/*结点的权值*/ int parent;/*结点的双亲*/ int lchild;/*结点的左孩子*/ int rchild;/*结点的右孩子*/ int flag;/*是否用过的标志*/ }HufmTree; int p1,p2;/*...

绥德县15138852703: 哈夫曼树的构造,关键字如图 -
希容川贝: 哈夫曼树构造规则:假设有n个权值,则构造出的哈夫曼树有n个叶子结点. n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为:(1) 将w1、w2、…,wn看成是有n 棵树的森林(每棵树仅有一个结点);(2) 在森林中选出两个根结点的权值最小的树合并,作为一棵新树的左、右子树,且新树的根结点权值为其左、右子树根结点权值之和;(3)从森林中删除选取的两棵树,并将新树加入森林;(4)重复(2)、(3)步,直到森林中只剩一棵树为止 根据上述步骤得到的哈夫曼数是 (100) / \ (43) 57 / \ / \ (20) 23 (27) 30 / \ / \9 (11) 11 16 / \ 4 7

绥德县15138852703: 哈夫曼树怎样构造编码? -
希容川贝: 先编造哈夫曼树,哈夫曼树构造规则: 假设有n个权值,则构造出的哈夫曼树有n个叶子结点. n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为: (1) 将w1、w2、…,wn看成是有n 棵树的森林(每棵树仅有一个结点); (2) ...

绥德县15138852703: 构造哈夫曼树 -
希容川贝: 第一步排序 2 3 6 7 10 19 21 32 构图如下 谢谢提醒 我粗心了…… 字符版 复制到记事本里看********o********** *******/*\********* *****o*****o******* ****/*\***/*\****** ***19*21**o**32**** *********/*\******* ********o***o****** *******/*\*/*\***** *******o*6*7*10**** ******/*\********** ******2*3**********

绥德县15138852703: 怎样构造哈夫曼树及其带权路径的求法 -
希容川贝: 其中每颗二叉树TI中只有一个带权WI的根节点,其左右子树为空.(2)在F中选取两颗根节点的权值最小的树作为左右子树构造一颗新的二叉树.parent=i;HT[i].lchild=s2;HT[i].rchild=s1;HT[i].weight=HT[s1].weight+HT[s2].weight.这棵树就是哈弗曼...

绥德县15138852703: 有关构造哈夫曼树的问题 -
希容川贝: 1. 根据给定的n个权值{w1,w2,…wn}构成n棵二叉树的集合F={T1,T2,..,Tn},其中每棵二叉树Ti中只有一个带权wi的根结点,左右子树均空. 2. 在F中选择两棵根结点权值最小的树作为左右子树构造一棵新的二叉树,且置新的二叉树的根结点的权值...

绥德县15138852703: 请简述哈夫曼树的应用领域.已知字符A B C D E F的权值为8 12 5 20 4 11,请写出构造哈夫曼树的过程,并为这些字符设计哈夫曼编码,一步一步的! -
希容川贝:[答案] 哈夫曼树的应用领域:数字传输编码压缩.先编造哈夫曼树,哈夫曼树构造规则:假设有n个权值,则构造出的哈夫曼树有n个叶子结点.n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为:(1) 将w1、w2、…,wn看成是有n ...

绥德县15138852703: 哈夫曼树构造算法中j<ni是什么意思我不太懂这个循环的意思
希容川贝: 先看一下哈夫曼树的构造规则是:假设有n个权值,则构造出的哈夫曼树有n个叶子结点. n个权值分别设为 w1、w2、…、wn,则哈夫曼树的构造规则为:(1) 将w1、w...

绥德县15138852703: 到底什么是哈夫曼树啊,求例子 -
希容川贝: 哈夫曼树是给定n个权值作为n个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree).哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近. 例子: 1、将w...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网