数据结构哈夫曼树怎么计算画图

作者&投稿:毅廖 (若有异议请与网页底部的电邮联系)
哈夫曼编码的计算方法,并构建出哈夫曼树?重点是要会计算和绘图。。哪位能帮我讲解个例题吗?~



哈夫曼树 74
/ \
42 32
/ \ / \
23 19 12 20
/ \ / \
15 8 9 10
/ \
8 7
/ \
3 5
编码:A(010)B(00000)C(00001)D(001)E(10)F(11)G(0001)H(011)
带权路径长度值为:(3+5)*5+7*4+(8+9+10)*3+(12+20)*2=213
This is it!!! 求采纳

每次选当前集合中最小的两个数相加得到一个新的数,删掉原先的数加入新的数直到只剩一个数为止


有关构造哈夫曼树的问题
该树即为哈夫曼树 帮你贴过来了,百度百科 这东西实际用法是可以减少树的访问次数,因为他把频率高的点放在比较靠近根节点的地方,频率低的在下面,这样访问速度快。举个例子,比如四个点,他们的使用频率分别是1,2,3,4,然后构成的树就是 4 0 3 0 2 0 1补:打不出树形结构...

有人可以帮我注释一段关于用c语言实现哈夫曼树的代码吗?
int start;} HCodeType; \/* 编码结构体 *\/typedef struct{int weight;int parent;int lchild;int rchild;int value;} HNodeType; \/* 结点结构体 *\/\/* 构造一颗哈夫曼树 *\/void HuffmanTree (HNodeType HuffNode[MAXNODE], int n){\/* i、j: 循环变量,m1、m2:构造哈夫曼树不同...

利用 数据结构 实现 哈夫曼编码\/译码实现
\/\/哈夫曼编码结构体,包括编码数组和起始位void reading_file(Message *message);\/\/从文件中读取信息int writing_file(Message *message);\/\/将信息写进文件void total_message(Message *message,Total *total);\/\/统计信息中各字符的次数void HaffmanTree(Total *total,HNodetype HuffNode[]);\/\/构建哈夫曼树void ...

哈夫曼树左小右大是指什么
一、概念与定义 路径:从树的一个结点到另一个结点的分支构成这两个结点之间的路径,对于哈夫曼树特指从根节点到某节点的路径。路径长度:路径上的分支数目叫做路径长度。树的路径长度:从树根到每一结点的路径长度之和。权:赋予某一个事物的一个量,是对事物的某个或某些属性数值化描述。在数据结...

求一棵带权为1,1,1,2,2,3,4,5的最优二元树T,并计算它的权W(T)._百度...
1和2先结合生成节点3,3和3结合成6,6再和4结合,顺序是依次往右走,再用各个权植乘以树高相加即可。假设有n个权值,则构造出的哈夫曼树有n个叶子结点。 n个权值分别设为 w1、w2、wn,则哈夫曼树的构造规则为:(1) 将w1、w2、wn看成是有n 棵树的森林(每棵树仅有一个结点);(2) 在森林...

第十一章:树结构应用之哈夫曼编码解码
给定n个权值作为n个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近。编码:1.输入字符串,通过getWeight()获取其权重即每个字符出现的次数并利用权重及字符生成Node...

树- 哈夫曼树及其应用 - 最优二叉树(二)
注意 ① 初始森林中的n棵二叉树 每棵树有一个孤立的结点 它们既是根 又是叶子 ② n个叶子的哈夫曼树要经过n 次合并 产生n 个新结点 最终求得的哈夫曼树 *** 有 n 个结点 ③ 哈夫曼树是严格的二叉树 没有度数为 的分支结点 哈夫曼树的存储结构及哈夫曼算法的实现 ( ) 哈夫曼树的存储结构...

为什么99个结点的哈夫曼树,用二叉链表,它的空指针域会是51个?_百度知...
这个现象源于二叉链表的结构特点。在二叉链表中,每个节点通常只有一个子节点,且遵循“左孩子右兄弟”的规则,这意味着除了根节点外,每个节点都有一个空指针域指向其兄弟节点。对于99个节点的哈夫曼树,其中50个是叶子节点,这些叶子节点没有兄弟节点,因此它们不需要空指针。而剩余的99-50=49个非叶子...

哈夫曼树与哈夫曼编码、集合
什么是哈夫曼树(Huffman Tree) eg:将百分制的考试成绩转换为五分制的成绩 if ( score < 60 ) grade = 1; else if ( score < 70 ) grade = 2; else if ( score < 80 ) grade = 3; else if ( score < 90 ) grade = 4; else grade = 5; 建立判定树,...

树- 哈夫曼树及其应用 - 哈夫曼编码 (二)
( )字符集编码的存储结构及其算法描述 typedef struct { char ch; \/\/存储字符 char bits[n+ ]; \/\/存放编码位串 }CodeNode;typedef CodeNode HuffmanCode[n];void CharSetHuffmanEncoding(HuffmanTree T HuffmanCode H){\/\/根据哈夫曼树T求哈夫曼编码表H int c p i;\/\/c和p分别指示T中孩子和...

上街区18397417456: 请描述哈夫曼算法,并用图描述构造哈夫曼树的过程. -
蒸樊帅立: 这个讲的相当清楚.首先介绍什么是哈夫曼树.哈夫曼树又称最优二叉树,是一种带权路径长度最短的二叉树.所谓树的带权路径长度,就是树中所有的叶结点的权值乘上其...

上街区18397417456: 数据结构画Huffman树和计算带权路径长度 -
蒸樊帅立: 首先选择最小的4,5 得到9 则在{6,7,9,10,12,18}中选出最小的6,7得到13,继续在{9,10,12,13,18}选出最小的两个9,10,最后可以得到的树就是下面的树 62 25 37 12 13 18 19 6 7 9 10 4 5 两个叶子节点加起来就是根节点 这里不能画图 不是很清楚,但是应该也能明白, WPL=(4+5)*4+(6+7+10)*3+(12+18)*2=165 需要代码的话给邮箱,如果问题已解决,请采纳

上街区18397417456: 数据结构,构造哈夫曼树,求树的带权路径长度用6个权值分别为6、13、18、30、7和16的结点构造一棵哈夫曼(Huffman)树,该树的带权路径长度为答... -
蒸樊帅立:[答案] =6*4+7*4+13*3+30*2+16*2+18*2=219吧,根结点的值不对哦

上街区18397417456: 数据结构哈夫曼树的算法 -
蒸樊帅立: 每次取最小的2个合并后的值继续加入集合进行比较,直到集合里只有一个数为止,这样就可以达到权值最小的路径越长,权值越大的路径越短,即可以找到最小权值路径

上街区18397417456: 请描述哈夫曼算法,并用图描述构造哈夫曼树的过程. -
蒸樊帅立: 1. 根据给定的n个权值{w1,w2,…wn}构成n棵二叉树的集合F={T1,T2,..,Tn},其中每棵二叉树Ti中只有一个带权wi的根结点,左右子树均空. 2. 在F中选择两棵根结点权值最小的树作为左右子树构造一棵新的二叉树,且置新的二叉树的根结点的权值...

上街区18397417456: 在数据结构中给定叶子权值怎样构造哈夫曼树 -
蒸樊帅立: 从终端结点开始,删选最小值,构建二叉树,到根结点结束.使得带权路径长度WPL最小.

上街区18397417456: 数据结构的问题,求一个构造哈夫曼树的算法 -
蒸樊帅立: void haffmantree(int weight[],int n,struct haffnode hafftree[],char data[]) /*建立叶结点个数为n,权值数组为weight[]的哈夫曼树*/ {int i,j,m1,m2,x1,x2; /*哈夫曼树hafftree[]初始化,n个叶结点共有2n-1个结点*/ for(i=0;i {if(i hafftree[i].weight=weight[i]; ...

上街区18397417456: 给定一组权W={3,5,10,12,15,22} 构造哈夫曼树,并计算它的带权外部路径长度WPL. -
蒸樊帅立: 从根节点到各个百叶节点的路径长度与对应叶节点权值的乘度积之和内 22的路径长度是1 10、12、15的路径长度是3 3、5的路径长度是4 所以容WPL = 22 + (10 + 12 + 15) * 3 + (3 + 5) * 4 = 22 + 111 + 32 = 165

上街区18397417456: 数据结构问题:怎么计算?1.一棵有n个叶子结点的哈夫曼树共有__2n - 1 - 个结点.2、顺序查找查找成功时的最坏比较次数为(n - 1)和查找失败时的比较次数... -
蒸樊帅立:[答案] 1、建议你看看哈夫曼树的生成方法,n个叶子节点,看做n个森林,(1)挑权值最小的两个将其权值相加作为他们的亲节点,这时就有n-1个森林,亲结点权值参与新的比较;(2)重复1,直到将整个森林变为一棵树.很显然n个叶子节...

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