数据结构哈夫曼编码(源代码).docVIP

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
#includestdio.h #includestdlib.h #includemath.h #includestring.h #defineN1000 charkind[N]={\0}; intnum[N]={0}; intcount=0; ints1,s2; typedefstruct { intweight;/*字符权重*/ intparent,lchild,rchild; }HTNode,*HuffmanTree;/*定义哈夫曼树结点*/ typedefchar**HuffmanCode; structcharcode { chardata; charcode[20]; }Code[N],d[N],e[N]; voidCreat_message( )/*输入字符并存入文件*/ { FILE*fp; charc; if((fp=fopen(文本文件.txt,wb))==NULL) { printf(cannotopenthisfile!\n); return; } printf(请输入原代码,以#表示结束\n); do{ scanf(%c,c); fputc(c,fp); }while(c!=#); fclose(fp); } voidCalculate( )/*计算文件中字符的权值*/ { charc; inti=1,k; FILE*fp; if((fp=fopen(文本文件.txt,rb))==NULL){ printf(cannotopenthisfile\n); return; } c=fgetc(fp); while(c!=#){ for(k=0;ki;k++) if(c==kind[k]){ num[k]++;break;} if(k=ikind[k-1]!=c){ kind[i]=c;num[i]++;i++; } c=fgetc(fp); } count=i-1; } voidselect(HuffmanTreeHu,intj)/*找寻输入的字符数据中权值最小的两个结点*/ { intk=1,t; while(Hu[k].parent!=0)k++; for(t=k;t=j;t++) if(Hu[t].parent==0Hu[t].weightHu[k].weight) k=t; s1=k; k=1; while(Hu[k].parent!=0||k==s1)k++; for(t=k;t=j;t++) if(Hu[t].weightHu[k].weightHu[t].parent==0t!=s1) k=t; s2=k; } voidHuffmanCoding( )/*建立哈夫曼树并编码*/ { voidselect(HuffmanTreeHu,intj); HuffmanTreeHT; HuffmanCodeHC; intm,i,start,f,c; char*cd; FILE*fp; if(count=1)return; m=2*count-1; HT=(HuffmanTree)malloc((m+1)*sizeof(HTNode)); for(i=1;i=count;i++) HT[i].weight=num[i]; for(i=1;i=m;i++){ HT[i].parent=0; HT[i].lchild=0; HT[i].rchild=0;} for(i=count+1;i=m;i++){ select(HT,i-1); HT[s1].parent=i;HT[s2].parent=i; HT[i].lchild=s1;HT[i].rchild=s2; HT[i].weight=HT[s1].weight+HT[s2].weight;} HC=(HuffmanCode)malloc((count+1)*sizeof(char*)); cd=(char*)malloc(count*sizeof(char)); cd[count-1]=\0; for(i=1;i=count;i++){ start=count-1; for(c=i,f=HT[i].parent;f!=0;c=f,f=HT[f].parent) if(HT[f].lchild==c)cd[--start]=0; elsecd[--start]=1; HC[i]=(char*)malloc((count-start)*sizeof(char)); strcpy(HC[i],cd[start]);} if((fp=fopen(字符代码.txt,wb))==NULL) { printf(cannotopenthisfile\n); return; } for(i=1;i=count;i++){ Code[i].data=kind[i]; s

文档评论(0)

152****6621 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档