哈夫曼编码解码c++实现

作者&投稿:甘性 (若有异议请与网页底部的电邮联系)

树- 哈夫曼树及其应用 - 哈夫曼编码 (二)
\/\/若T[c]是T[p]的左孩子,则生成代码0;否则生成代码1 cd[--start]=(T[p).1child==C)?'0':'1';c=p; \/\/继续上溯 } strcpy(H[i].bits,&cd[start]); \/\/复制编码位串 }\/\/endfor }\/\/CharSetHuffmanEncoding 文件的编码和解码 有了字符集的哈夫曼编码表之后,对数据文件的编码过程...

斐波那契数列的哈夫曼编码是什么
斐波那契数列因为有着第k项是第(k-2)项与第(k-1)项的和的性质,致使它的前n项之和必定不小于第(n+1)项并比第(n+2)项小。所以如果给斐波那契数列的前8项别名为a-h,那么他们的编码有如下形式:a:0000000 b:0000001 c:000001 d:00001 e:0001 f:001 g:01 h:1 这个形式规律可以推广到n...

已知在一段文字中共有A,B,C,D,E,F,G,H八种字母,它们出现的次数分别是9...
\/ \\ \/ \\ 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 这个就是哈夫曼树及其编码,是计算机中数据结构的一个概念,...

哈夫曼编码 . 已知字母A、B、C、D、E、F、G 出现的概率分别是0.03, 0...
0.15 0.27 F0.28 G0.30 \/ \\ \/ \\ 0.05 C0.10 D0.13 E0.14 \/ \\ A0.02 B 0.03 哈夫曼编码是:A: 0000 B:0001 C:001 D:010 E:011 F:10 G:11

哈夫曼编码的平均码长是多少?
假设用于通信的电文由字符集{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}.哈夫曼编码 根据上面可得编码表: a:1001 b:01 c:10111 d:1010 e:11 f:10110 g:00 h:1000 用三位二进行数进行的...

哈夫曼编码中如果编出来信源a1、a2、a3、a4,分别用0,10,110,1110,1111...
int m,i,s[2],c,f,end=0,j,k;char linshi[50];if (n<=1) return;m=2*n-1;fp = fopen ("hfmtree.txt","w+");for (i=1;i<=n;++i){ HT[i].zifu=zi[i];HT[i].weight=w[i];HT[i].parent=0;HT[i].lchild=0;HT[i].rchild=0;} for (;i<=m;++i){ HT[i]...

...求大神提供完整代码(c或c++),不胜感激啊…… 利用哈夫曼编码...
<<"D.利用已建好的哈夫曼树将文件中的代码进行译码\\n"<<"P.将编码文件显示在终端上面并保存在文件中\\n"<<"T.打印哈弗曼树\\n"<<"O.退出系统"<<endl;func();} void func(){ cout<<"输入相应字母,实现对应功能:";char c;cin>>c;switch(c){ case'I':case'i':cout<<"请先输入字符...

哈夫曼编码原理
赫夫曼码的码字(各符号的代码)是异前置码字,即任一码字不会是另一码字的前面部分,这使各码字可以连在一起传送,中间不需另加隔离符号,只要传送时不出错,收端仍可分离各个码字,不致混淆。哈夫曼编码,又称霍夫曼编码,是一种编码方式,哈夫曼编码是可变字长编码(VLC)的一种。Huffman于1952年...

哈夫曼编码左边是0还是1
生成法则则是:把数据使用的频率当做权重,先将两个权重最低的相加。再在剩余的权重里面,再找出使用频率最低的两个,以此类推。权重小的放在左边,大的在右边。直到遍历完全部的数据,哈夫曼树就生成了。而哈夫曼编码,则是从根节点开始,左节点标记为0,右节点标记为1.例:a,b,c,d,e 对应出现...

【离散数学】树(一)哈夫曼编码基本原理
从根结点开始,遇到 0 ,向左下移动一次,得到字符 A 开始解码下一个字符,从根结点开始,遇到2个 1 ,向右下移动2次,遇到 0 ,向左下移动一次,得到字符 C 开始解码下一个字符,从根结点开始,遇到5个 1 ,向右下移动5次,得到字符 E 所以我们解码得到的字符为 ACE 关于哈夫曼编码的...

温张18639039099问: 急求一个C++程序 哈夫曼编码 -
禹城市鞣酸回答: #include <fstream.h>#include <stdlib.h>#include <string.h>#define CAPS ch>=65&&ch<=90 //定义宏,用于判断大小写#define LOWS ch>=97&&ch<=122 struct Huffman{ Huffman *pnext,*pl,*pr; //pnext用于建立链表,pl、pr用于建立哈夫曼树 char ...

温张18639039099问: 写个哈夫曼编码译码程序 数据结构 c++ -
禹城市鞣酸回答: #include #include #includetypedef struct { int weight; int parent,lchild,rchild; char data; }HTNode,*HuffmanTree; typedef char **HuffmanCode; void tongji(char *a,int *w,char *d,int &n) { int j=0; for(int i=0;i if(a[i]==d[k]) { w[k]++; break; } } if(k==j){ d[j]=a[i];...

温张18639039099问: 哈夫曼树和编码应用用C++实现 -
禹城市鞣酸回答: #include <stdio.h> #define MAXBIT 10 /*定义哈夫曼编码的最大长度*/ #define MAXVALUE 10000 /*定义最大权值*/ #define MAXLEAF 30 /*定义哈夫曼树中最多叶子节点个数*/ #define MAXNODE MAXLEAF*2-1 /*哈夫曼树最多结点数*/ typedef ...

温张18639039099问: 求高手帮编写用数据结构实现哈夫曼树的编码和译码的程序(c++)最好能有300行 急用 -
禹城市鞣酸回答: #include<iostream.h>#include<string.h>#define maxsize 100#define n 5#define m 2*n-1 int start=0; typedef struct { int weight; int parent,lchild,rchild; }htnode; typedef htnode huffmantree[maxsize]; // 动态分配数组存储赫夫曼树 int min(huffmantree t,...

温张18639039099问: 哈夫曼编码/译码器的实现用C++面向对象,用CLASS封装(不要C语言,用顺序表存储) -
禹城市鞣酸回答: 参考这个:http://zhidao.baidu.com/link?url=qfz0NyWy_cNy2_X2M1CM4Z8JW0vA4nNi0CTZTQ8gAXXpN_AMhFOxD9_mslghqVqd-uVzp53fpjdD2yCgpQRl9a 大约这些功能:void prin(){ //终端输出选择菜单 cout<<"---------------------------------------...

温张18639039099问: 数据结构C++实现哈夫曼树 -
禹城市鞣酸回答: 看程序代码: #include"stdlib.h" #include <iostream.h>#include <iomanip.h> const int n=10;//字符的最大个数 struct hufnode {char elem;int m_weight;int parent,lchild,rchild; //两个叶子节点回溯到跟节点 }; typedef struct hufnode htnode; ...

温张18639039099问: C++哈夫曼编码译码实现 -
禹城市鞣酸回答: 这个是哈夫曼压缩文件的代码,可以给你参考下,VC6编译通过,可以正常压缩和解压...

温张18639039099问: 数据结构题目,关于哈弗曼编码,用C语言来做(非常急的,谢谢了) -
禹城市鞣酸回答: void HuffmanCoding(HuffmanTree &HT, HuffmanCode &HC, int *w, int n) { // w存放n个字符的权值(均>0),构造哈夫曼树HT, // 并求出n个字符的哈夫曼编码HC int i, j, m, s1,s2; char *cd; int p; int cdlen; if (n m = 2 * n - 1; HT = (HuffmanTree)...

温张18639039099问: 用C++编写Huffman码 -
禹城市鞣酸回答: 使用说明:首先建立哈夫曼树,输入你的信号源的个数,然后输入每个信号的符号及其相应的频率(最后乘以100不要出现小数的为好)我的输入文件名为Myinput.txt即在C盘下建立文本文档取名为Myinput.txt然后输入你的信号的符号以空格结束...

温张18639039099问: C++哈夫曼编码实现文件压缩 -
禹城市鞣酸回答: 有,int <bit_vector> bv={0,1,1,0,1}; 标准模板类 按位存放


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