欢迎访问有用文档网!

当前位置: 有用文档网 > 述职报告 >

哈夫曼编码实验报告

| 浏览次数:

 实验报告与总结 一、 实验目得

 1、掌握哈夫曼编码原理; 2、熟练掌握哈夫曼树得生成方法;

  3、理解数据编码压缩与译码输出编码得实现. 二、实验要求

 实现哈夫曼编码与译码得生成算法。

 三、实验内容 先统计要压缩编码得文件中得字符字母出现得次数,按字符字母与空格出现得概率对其进行哈夫曼编码,然后读入要编码得文件,编码后存入另一个文件;接着再调出编码后得文件,并对其进行译码输出,最后存入另一个文件中。

 五、实验原理 1、哈夫曼树得定义:假设有 n 个权值,试构造一颗有 n 个叶子节点得二叉树,每个叶子带权值为 wi,其中树带权路径最小得二叉树成为哈夫曼树或者最优二叉树; 2、哈夫曼树得构造: weight为输入得频率数组,把其中得值赋给依次建立得 HT Node对象中得 data 属性,即每一个 HT Node 对应一个输入得频率。然后根据 data 属性按从小到大顺序排序,每次从data 取出两个最小与此次小得 HT Node,将她们得 data相加,构造出新得HTNode 作为她们得父节点,指针 parent,leftchild,rightchild赋相应值。在把这个新得节点插入最小堆。按此步骤可以构造构造出一棵哈夫曼树。

 通过已经构造出得哈夫曼树,自底向上,由频率节点开始向上寻找 parent,直到 parent为树得顶点为止。这样,根据每次向上搜索后,原节点为父节点得左孩子还就是右孩子,来记录1或 0,这样,每个频率都会有一个01编码与之唯一对应,并且任何编码没有前部分就是同其她完整编码一样得。

 六、实验流程

 ① 初始化,统计文本文件中各字符得个数作为权值,生成哈夫曼树; ② 根据符号概率得大小按由大到小顺序对符号进行排序;

 ③ 把概率最小得两个符号组成一个节点; ④ 重复步骤(2)(3),直到概率与为1; ⑤ 从根节点开始到相应于每个符号得“树叶”,概率大得标“0”,概率小得标“1”; ⑥ 从根节点开始,对符号进行编码; ⑦ 译码时流程逆向进行,从文件中读出哈夫曼树,并利用哈夫曼树将编码序列解码。

 七、实验程序

 #include〈iostream〉 #include〈fstream> #include<iomanip> #include<vector>

 using namespace std; typedef struct

  //节点结构 {

 char data;

 //记录字符值

 重权符字录记//

 ;thgiew tni gnolﻩ unsigned int parent,lchild,rchild; }HTNode,*HuffmanTree;

 //动态分配数组存储哈夫曼树 typedef char * *HuffmanCode;

  //动态分配数组存储哈夫曼编码表 void Select(HuffmanTree &HT,int i,int &s1,int &s2)

 //在 HT[1、、、t]中选择parent 不为 0 且权值最小得两个结点,其序号分别为s1 与 s2

 {

 ;0=2s;0=1sﻩ ;00003=2n,00003=1n tniﻩ for(int k=1;k<=i;k++)

 {ﻩ

 if(HT[k]、parent==0)

  {

 )1n<thgiew、]k[TH(fiﻩ ﻩ

 {

 ﻩﻩﻩ n2=n1; n1=HT[k]、weight;

 ﻩﻩﻩ s2=s1; s1=k;

 }

 esleﻩ

 ﻩ

 if(HT[k]、weight〈n2)

  {ﻩﻩﻩ

  n2=HT[k]、weight;

  ﻩﻩ

 s2=k;

 ﻩ }

  }ﻩ }ﻩ} void HuffmanCoding(HuffmanTree &HT,HuffmanCode &HC,int n)//将要编码得字符串存入空树中 {

 ifstream fin1(”zifu、txt");

 ifstream fin2("weight、txt”);

 if(n〈=1)return;

 int m=2*n—1;

 int i;

 ;]1+m[edoNTH wen=THﻩ char *zifu;

 int *weight;

  zifu= new char[n+1];

 weight=new int[n+1];

 中组数 ufiz在放符字得码编待将//)++i;n=〈i;1=i(rofﻩ

  {ﻩ ;hc rahcﻩﻩ

 ch=fin1、get();

 ;hc=]i[ufizﻩﻩ }

 中组数 thgiew 在放值权得应对符字码编带将//)++i;n=〈i;1=i(rofﻩ {ﻩ

 fin2〉〉weight[i];

 }

 for( i=1;i〈=n;i++)

 {

  ;]i[ufiz=atad、]i[THﻩ ;]i[thgiew=thgiew、]i[THﻩﻩ }ﻩ for(i=n+1;i<=m;i++)

 {

  HT[i]、data=’';

 }ﻩ )++i;m=〈i;1=i(rofﻩ {

  HT[i]、parent=HT[i]、lchild=HT[i]、rchild=0;

 }ﻩ )i++;m=<i;1+n=i(rofﻩ {

 ;2s,1s tniﻩﻩ

 Select(HT,i—1,s1,s2);

  HT[s1]、parent=i;

 HT[s2]、parent=i;

 ;2s=dlihcr、]i[TH

 ;1s=dlihcl、]i[THﻩﻩ ;thgiew、]2s[TH+thgiew、]1s[TH=thgiew、]i[THﻩﻩ }

 间空作工得码编求个一辟开;))*rahc(foezis*)1+n((collam)edoCnamffuH(=CHﻩ ;dc* rahcﻩ 值权放存间空辟开//;))rahc(foezis*n(collam)* rahc(=dcﻩ cd[n-1]="\0’; for(i=1;i<=n;i++) {

  ;1-n=trats tniﻩ

 ;f,c tniﻩ

 for( c=i, f=HT[i]、parent;f!=0;c=f,f=HT[f]、parent)//从叶子到根逆向求编码

  {

  ﻩ if(HT[f]、lchild==c)

 ﻩ

 ﻩ cd[—-start]=’0’;//若就是左孩子编为"0"

 esleﻩ ﻩ

 "1’为编子孩右是就若//;"1"=]trats—-[dcﻩﻩ

  }ﻩﻩ分码编个i第为//

 ;))rahc(foezis*)trats-n((collam)* rahc(=]i[CHﻩ配空间

  strcpy(HC[i],&cd[start]);

 }ﻩ delete []cd;

 //释放工作空间 } void printHuffmanTree(HuffmanTree HT,int n)

 //显示有 n 个叶子结点得哈夫曼树得编码表 {

  ofstream fout("hfmtree、txt");

 //将对应字符得得哈弗曼树存入 "

  ”<〈”tnerap"<<”

  ”<<"thgiew”〈<”

  "〈<"atad”〈〈”

  "〈〈”MUN"<〈tuocﻩ〈<"lchild"<<”

  ”<〈"rchlid”〈〈endl;

 for(int i=1;i<=2*n—1;i++)

 {

 ﻩ fout<〈HT[i]、weight〈〈setw(3)〈<HT[i]、parent〈〈setw(3)<<HT[i]、lchild<<setw(3)〈<HT[i]、rchild<<endl; <〈thgiew、]i[TH<〈)3(wtes〈<atad、]i[TH〈<)5(wtes<〈i〈〈tuocﻩﻩsetw(3)〈<HT[i]、parent<<setw(3)<<HT[i]、lchild〈〈setw(3)<<HT[i]、rchild〈〈endl;

 } } void printHuffmanCoding(HuffmanTree HT,HuffmanCode HC,int n)//输出字符得对应哈弗曼编码并存入 code、txt 文件 {

 cout<〈"Huffman code is:”<〈endl;

 ;)”txt、edoc”(tuof maertsfoﻩ for(int i=1;i<=n;i++)

 {ﻩ

 cout<〈HT[i]、data<<” —-> ";

  ;ldne〈<)]i[CH(<<tuocﻩ ;ldne<<)]i[CH(<〈tuofﻩﻩ }ﻩ} void code_ HT,HuffmanCode HC,int n)//对文件 tobetran、txt 进行编码,并将编码存入 codefile 文件中 {

 ifstream fin("tobetran、txt");

 ;)”edoc”(tuof maertsfoﻩ ;a 〉rahc〈rotcevﻩ ;hc rahcﻩ )’*"=!))(teg、nif=hc((elihwﻩ

 a、push_back(ch);

  cout〈<"待编码得字符串为:";

 )++k;)(ezis、a<k;0=k tni(rofﻩ ;]k[a〈〈tuocﻩﻩ

  ;ldne〈〈tuocﻩ ;ldne<<":果结码编 n\"〈〈tuocﻩ )++i;)(ezis、a〈i;0=i tni(rofﻩ {

 )++j;n=〈j;1=j tni(rofﻩ {ﻩﻩﻩ)atad、]j[TH==]i[a(fiﻩ

  {ﻩ ﻩ

 fout〈<HC[j];

 ;kaerbﻩﻩ

  }

 ﻩ }

 }ﻩ fin、close();

 ;)(esolc、tuofﻩ} void Decoding(HuffmanTree HT,HuffmanCode HC,int n)//打开 codefile 文件并对文件内容进行译码 {

 int const m=2*n—1;

 ifstream fin("code”);

 ;)"txet"(tuof maertsfoﻩ vector<char> a;

 );c>>nif;c rahc(rofﻩ

 a、push_back(c);

  ;0=tnuoc tniﻩ for(int k=0;k<a、size();k++)

 {

  ﻩ cout〈〈a[k];

 ﻩ count++;

 ﻩ if(count%50==0)

 ﻩ;ldne〈<tuocﻩ }ﻩ int i=0;

 值得 m 住记来 p 用//

  ;p tniﻩ cout<〈endl;

 cout<<”\n 译码结果:”<〈endl;

 while(i〈a、size())

 {ﻩ 历遍始开根得数曼弗哈从//

 ;m=pﻩﻩ

 )dlihcl、]p[TH(elihwﻩ

 {

  )’1’==]i[a(fiﻩ

  ;dlihcr、]p[TH=pﻩﻩ

  else

 ﻩ ;dlihcl、]p[TH=pﻩ

  ;++iﻩ

 }

 ﻩ fout<<HT[p]、data;

 ;atad、]p[TH〈〈tuocﻩ } } void main() {

 int n;

 cout<<”输入权值个数:”;

 //设置权值数值

 ;n>〉nicﻩ ;)"n\”(ftnirpﻩ TH 树曼夫哈//

  ;TH eerTnamffuHﻩ CH表码编曼夫哈//

  ;CH edoCnamffuHﻩ 码编曼夫哈行进//

 ;)n,CH,TH(gnidoCnamffuHﻩ printHuffmanCoding(HT,HC,n);

 //显示编码得字符

 ;)"n\"(ftnirpﻩ code_);

  //显示要编码得字符串,并把编码值显示出来

 串符字得后码译示显并码译//

  ;)n,CH,TH(gnidoceDﻩ ;)”n\n\n\”(ftnirpﻩ ;)"esuap"(metsysﻩ}

  八、结果分析 哈夫曼编码就是动态变长编码,临时建立概率统计表与编码树。概率小得码比较长,概率小得码比较长。概率大得码短,这样把一篇文件编码后,就会压缩许多。从树得角度瞧,哈夫曼编码方式就是尽量把短码都利用上。首先,把一阶节点全都用上,如果码字不够时,然后,再从某个节点伸出若干枝,引出二阶节点作为码字,以此类推,显然所得码长最短,再根据建立得概率统计表合理分布与放置,使其平均码长最短就可以得到最佳码。

 九、实验总结

 通过这次实验,我对二叉树与哈希曼树有了更好得认识。在实验过程中,我掌握了哈曼树得构造方法,学会了如何将理论知识传换成实际应用。同时,在解决程序中遇到得一些问题得同时,我也对调试技巧有了更好得掌握,分析问题得能力也略有提高. 在实验中,我遇到了许多难点,比如:统计字符得权值,就需要我们有扎实得基础,需要有灵活得头脑,只有不断得练习,不断得训练,我们才能处理各种问题.在以后得学习中,我要不断得努力,多联系,多思考,我相信我能有所进步得。

推荐访问:编码 实验 报告

上一篇:php实验报告一

下一篇:倒立摆实验报告

热门排行Top Ranking

弦振动实验报告

弦振动得研究 一、实验目得 1、观察固定均匀弦振动共振干涉形成驻波时得波形,加深驻波得认识。 2、了

宣传委员述职报告12020 幼儿园党支部宣传委员述职报告

下面是小编为大家精心整理的宣传委员述职报告12020幼儿园党支部宣传委员述职报告文章,供大家阅读参考。宣传委员述

党建工作现场述职会上讲话 公安局长在党建工作现场会上的讲话

下面是小编为大家精心整理的党建工作现场述职会上讲话公安局长在党建工作现场会上的讲话文章,供大家阅读参考。党建工作现场

支部宣传委员述职述廉报告范例 幼儿园党支部宣传委员述职报告

下面是小编为大家精心整理的支部宣传委员述职述廉报告范例幼儿园党支部宣传委员述职报告文章,供大家阅读参考。支部宣传

政治生态评估报告5篇

可能会捆绑住经办人员的手脚,不利于业务工作的开展。致使个别中层干部主体责任压力传导出现能量损耗;个别

2021年领导述职报告合集2020 县领导述职报告

下面是小编为大家精心整理的2021年领导述职报告合集2020县领导述职报告文章,供大家阅读参考。2

工商局监察室主任述职述廉报告

工商局监察室主任述职述廉报告 第一篇:工商局监察室主任述职述廉报告 我叫haoword,中共党员,现

党支部书记个人述职报告 对村党支部书记述职报告的点评

下面是小编为大家精心整理的党支部书记个人述职报告对村党支部书记述职报告的点评文章,供大家阅读参考。党支部书记个人

财务分析课程报告4篇

财务分析课程报告4篇财务分析课程报告篇1一年来,在领导和同事们的的支持帮助和指导下,加上自身的不断努

结合乡村振兴战略人才工作述职报告 乡村振兴工作员年度述职

下面是小编为大家精心整理的结合乡村振兴战略人才工作述职报告乡村振兴工作员年度述职文章,供大家阅读参考。结合

个人安全生产履职报告[安全生产述职报告] 党委书记安全生产履职报告

下面是小编为大家精心整理的个人安全生产履职报告[安全生产述职报告]党委书记安全生产履职报告文章,供大家阅读参

企业年度工作总结报告范文13篇

企业年度工作总结报告范文13篇企业年度工作总结报告范文篇1时光飞逝,转眼已经毕业一年了,我顺利地完成