1、 int weight;/结点权值 int parent; int lchild; int rchild; char inf;HNodeType; 2、求哈夫曼编码时使用一维结构数组HuffCode作为哈夫曼编码信息的存储。 求哈夫曼编码,实质上就是在已建立的哈夫曼树中,从叶子结点开始,沿结点的双亲链域回退到根结点,没回退一步,就走过了哈夫曼树的一个分支,从而得到一位哈夫曼码值,由于一个字符的哈夫曼编码是从根结点到相应叶子结点所经过的路径上各分支所组成的0、1序列,因此先得到的分支代码为所求编码的低位码,后得到的分支代码位所求编码的高位码,所以设计如下数据类型:#define MAXBIT 1
2、0typedef struct int bitMAXBIT; int start;HcodeType; 3、文件nodedata.dat、code.dat和textfile.dat。三、【功能(函数)设计】 1、初始化功能模块。 此功能模块的功能为从键盘接收字符集大小n,以及n个字符和n个权值。2、建立哈夫曼树的功能模块。此模块功能为使用1中得到的数据按照教材中的构造哈夫曼树的算法构造哈夫曼树,即将HuffNode数组中的各个位置的各个域都添上相关的值,并将这个结构体数组存于文件hfmtree.dat中。3、建立哈夫曼编码的功能模块。此模块功能为从文件nodedata.dat中读入相关的字符信
3、息进行哈夫曼编码,然后将结果存入code.dat中,同时将字符与0、1代码串的一一对应关系打印到屏幕上。4、译码的功能模块。此模块功能为接收需要译码的0、1代码串,按照3中建立的编码规则将其翻译成字符集中字符所组成的字符串形式,存入文件textfile.dat,同时将翻译的结果在屏幕上打印输出。 四、【编码实现】 #include#includestring.hstdlib.h#define MaxBit 10#define Maxvalue 100/应该大于权重之和#define Maxleaf 100#define Maxnode Maxleaf*2-1struct HcodeType i
4、nt bitMaxBit; int start;void Creat_Haffmantree(int &n) HNodeType *HaffNode=new HNodeType2*n-1; int i,j; int m1,m2,x1,x2; for(i=0;i2*n-1;i+) HaffNodei.weight=0; HaffNodei.parent=-1; HaffNodei.lchild=-1; HaffNodei.rchild=-1; HaffNodei.inf=0; n; coutHaffNodei.inf;请输入该字符的权值HaffNodei.weight;n-1;i+)/构造哈夫曼
5、树 m1=m2=Maxvalue; x1=x2=0; for(j=0;jn+i;j+)/选取最小和次小 if(HaffNodej.parent=-1&HaffNodej.weightm1) m2=m1; x2=x1; m1=HaffNodej.weight; x1=j; else if(HaffNodej.parent=-1&m2) m2=HaffNodej.weight; x2=j; /将找出的最小和次小合并,创造其父母结点 HaffNodex1.parent=n+i; HaffNodex2.parent=n+i; HaffNoden+i.weight=HaffNodex1.weight+H
6、affNodex2.weight; HaffNoden+i.lchild=x1; HaffNoden+i.rchild=x2; HaffNoden+i.inf=NULL; cout显示存储的哈弗曼树信息:权值 左孩子 右孩子 双亲HaffNodei.weight HaffNodei.lchildHaffNodei.rchildHaffNodei.parentHaffNodei.inf /写入文件 fstream outfile1; outfile1.open(E:nodedata.dat,ios:out|ios:trunc|ios:binary);/建立进行写入的文件 if(!outfile1
7、) /没有创建成功则显示相应信息nodedata.dat文件不能打开 abort();i+) /将存中从HaffNodei地址开始的sizeof(HaffNodei)的容写入文件中 outfile1.write(char*)&HaffNodei,sizeof(HaffNodei); outfile1.close ();/关闭文件 delete HaffNode;void HaffCode(int &n)/哈夫曼编码 HNodeType *HaffNode=new HNodeTypeMaxnode; HcodeType *HaffCode=new HcodeTypeMaxleaf; HcodeT
8、ype cd; int i,j,c,p; fstream in(in|ios: in.read(char*)HaffNode,(2*n-1)*sizeof(HNodeType); in.close(); fstream outfile; outfile.open(codedata.dat cd.start=n-1; c=i; p=HaffNodec.parent; while(p!=-1) if(HaffNodep.lchild=c) cd.bitcd.start=0; cd.bitcd.start=1; cd.start-; c=p; p=HaffNodec.parent; for(j=cd.start+1;j+) HaffCodei.bitj=cd.bitj; HaffCodei.start=cd.start; outfile for(j=HaffCodei.start+1; outfileinf; int f=strlen(inf);code.datoutfile1)code.dat文件不能打开! abort(); else cout字符串编码后为: for(int x=0;xf;x+) if(infx=HaffNodei.inf) for(j=HaffCodei.start+1; outfile1.write(char*)&HaffCod
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1