版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数据结构实验报告实验题目:Huffman编码与解码学号:院系:实验名称:Huffman编码与解码实验问题描述:本实验需要以菜单形式完成以下功能:输入电文串统计电文串中各个字符及其出现的次数构造哈弗曼树进行哈弗曼编码将电文翻译成比特流并打印出来将比特流还原成电文数据结构的描述:逻辑结构:本实验可用二叉树实现,其逻辑结构为一对二的形式,即一个结点对应两个结点。在实验过程中我们也应用到了栈的概念。存储结构:使用结构体来对数据进行存储:typedef structint weight;int parent,lc,rc;HTNode,*HuffmanTree;typedef struct LNodech
2、ar *elem;int stacksize;int top;SqStack;在main函数里面定义一个哈弗曼树并实现上述各种功能。程序结构的描述:本次实验一共构造了 10个函数:void HuffTree(HuffmanTree &HT,int n,int mun);此函数根据给定的mun个权值构建哈弗曼树,n用于存放num个权值。void Select(HuffmanTree &HT,int n,int i,int &s1,int &s2);此函数用于在HT1,i-1 中选择parent为0且weight为最小的两个结点,其 下标分别为s1,s2.void HuffmanCoding(Hu
3、ffmanTree HT,char *&HC,int n);此函数从哈弗曼树HT上求得n个叶子结点的哈弗曼编码并存入数组HC 中。void Coding(HuffmanTree HT,char *HC,int root,SqStack &S);此函数用于哈弗曼编码,先序遍历哈弗曼树HT,求得每个叶子结点的编码 字符串,存入数组HC, S为一个顺序栈,用来记录遍历路径,root是哈弗曼数 组HT中根结点的位置下标。void InitStack(SqStack &S);此函数用于初始化一个栈。void Pop(SqStack &S,char e);此函数为出栈操作。void Push(SqStac
4、k &S,char e);此函数为进栈操作。8.int StackLength(SqStack S);此函数用于求栈长,返回一个int型的值。9.int Find(char a,char s,int num);此函数用于查找字符a在电文串中的位置。10.int Recover(HuffmanTree HT,char *HC,char string,char a,char b,int n);此函数用于将比特流还原成电文。调试分析:输入任意一个字符串,如输入welcometoustc:运行结果如下:习,习,习,习,习,习,习,习,习,次次次次次次次次次现现现现现现现现现rrrrrr出出出出出出出出
5、出O4XXXXXX于: TOC o 1-5 h z 4164io12141&16is哈弗曼编码: bl : 1110 e : 911 1 : 1111 E : 180 : 101 n - 000 t : 119 LL : 001 S : 010该电文的哈弗景编码为: 11100111111100101000011110101001010110100 请输入哈弗曼编码:按照提示输入任意一个或多个哈弗曼编码,如输入11111110101 :请输入哈弗景编码:11111110101 1U0结果正确。若输入一个11111 :请输入哈弗景编码,11111mi?结果正确。实验完成
6、!实验体会和收获:本次实验提高了对哈弗曼树的认识,同时加深了对二叉树的理解,在栈的运用上 更加熟练,对数组的应用也有了提高。源代码:#include#include#include#includetypedef structint weight;int parent,lc,rc;HTNode,*HuffmanTree;typedef struct LNode char *elem;int stacksize;int top;SqStack;#define size 20void HuffTree(HuffmanTree &HT,int n,int mun);void Select(Huffma
7、nTree &HT,int n,int i,int &s1,int &s2);void HuffmanCoding(HuffmanTree HT,char *&HC,int n);void Coding(HuffmanTree HT,char *HC,int root,SqStack &S);void InitStack(SqStack &S);void Pop(SqStack &S,char e);void Push(SqStack &S,char e);int StackLength(SqStack S);int Find(char a,char s,int num);int Recove
8、r(HuffmanTree HT,char *HC,char string,char a,char b,int n);int main()int i=0,nsize=0,j=0,k=1,num=0;char stringsize=0,msize=0,asize=0,bsize=0;char* HC;HuffmanTree HT;printf(请输入电文串:n);scanf(%s,string);strcpy(m,string);while(stringj)if(stringj! = #) ak=stringj;i=i;while(stringi)if(stringi=ak)stringi =
9、#;nk + + ;i+;if(nk!=0)printf(该电文中字符%c出现次数为%dn,ak,nk);num+ + ;k+ + ;j + + ;printf(哈弗曼树:n);HuffTree(HT,n,num);for(i = 1;i=2*num-1;i +)printf(%dt%dt%dt%dn,HTi.weight,HTi.parent,HTi.lc,HTi.rc);printf(哈弗曼编码:n);HuffmanCoding(HT,HC,num);for(i = 1;i = num;i +)printf(%c : %sn,ai,HCi);printf(n该电文的哈弗曼编码为:n);i=
10、0;while(stringi)printf(%s,HCFind(mi + +,a,num);printf(n请输入哈弗曼编码:n);scanf(%s,string);if(Recover(HT,HC,string,a,b,num) printf(%sn,b);else printf(代码有误!n”);system(pause);return 0;void HuffTree(HuffmanTree &HT,int n,int num)int i,m,s1,s2;m=2*num-1;HT=(HuffmanTree)malloc(m+1)*sizeof(HTNode);for(i = 1;i =
11、m;i+)HTi.weight=i = num?ni:0;HTi.lc=HTi.rc=HTi.parent=0;for(i = num+1;i = m;i +)Select(HT,num,i,s1,s2);HTi.lc=s1;HTi.rc=s2;HTi.weight=HTs1.weight+HTs2.weight;HTs1.parent=HTs2.parent=i;void Select(HuffmanTree &HT,int n,int i,int &s1,int &s2)int k,t;s1=s2=-1;k=1;while(s1= = -1)if(HTk.parent=0)s1=k;k+;
12、k=1;while(s2= = -1|s2=s1)if(HTk.parent=0)s2=k;k+ + ;if(HTs2.weightHTs1.weight)t=s2;s2=s1;s1=t;for(k=1;ki;k+)if(HTk.parent=0)if(HTk.weightHTs1.weight&k!=s1&k!二s2)s2=s1;s1=k;elseif(HTk.weight = HTs1.weight&k!=s1&k!二s2) s2=k;void HuffmanCoding(HuffmanTree HT,char *&HC,int n)SqStack S;InitStack(S);HC=(c
13、har*)malloc(n+1)*sizeof(char*);Coding(HT,HC,2*n-1,S);void Coding(HuffmanTree HT,char *HC,int root,SqStack &S)if(root!=0)if(HTroot.lc=0)Push(S,0);HCroot=(char*)malloc(StackLength(S);strcpy(HCroot,S.elem);Pop(S,0);Push(S,0);Coding(HT,HC,HTroot.lc,S);Pop(S,0);Push(S,1);Coding(HT,HC,HTroot.rc,S);Pop(S,0
14、);void InitStack(SqStack &S)S.elem=(char *)malloc(size*sizeof(char);S.stacksize二size;S.top=-1;void Push(SqStack &S,char e)S.elem+S.top=e;void Pop(SqStack &S,char e)if(S.top= = -1) return;e=S.elemS.top-;return;int StackLength(SqStack S)if(S.top= = -1) return(0);return(S.top);int Find(char a,char s,in
15、t num)int i;for(i = 1;i = num;i +)if(a=si) return i;return 0;int Recover(HuffmanTree HT,char *HC,char string,char a,char b,int n)int i=0,j=0,k,m=0,t=0,h=0;char ssize;k=2*n-1;while(stringi)if(!HTk.lc&!HTk.rc)if(stringi = = 0) (sj=0;k=2*n-1;t=1;j=0;)if(stringi = = 1)sj=0;k=2*n-1;t=1;j=0;for(h=1;h = n;h +)if(!strcmp(HCh,s)bm+=ah;elseif(stringi = = 0) (k=HTk.lc;sj +
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024-2030年中国外用止痛药行业竞争格局及投资价值研究报告
- 2024-2030年中国型煤(型焦)行业发展前景预测规划研究报告
- 2024-2030年中国四功能折叠健身器产业未来发展趋势及投资策略分析报告
- 2024-2030年中国印花涂料色浆市场运行状况及发展趋势预测报告
- 梅河口康美职业技术学院《有限元分析与可靠性设计》2023-2024学年第一学期期末试卷
- 眉山药科职业学院《小学道德与法治课程与教学》2023-2024学年第一学期期末试卷
- 2024年物业买卖合同范本:物业信息与交易条件
- 2024年度绿色建筑HSE施工与运维服务合同2篇
- 微专题物质的制备实验突破策略-2024高考化学一轮考点击破
- 2024年标准专业施工承包协议文件版B版
- 道德与法治中考备考建议课件
- 财产保险退保申请范文推荐6篇
- 食品工程原理课程设计
- YYT 0325-2022 一次性使用无菌导尿管
- 羊膜在眼科临床中应用课件
- (71)第十五章15.2.3整数指数幂1-负整数指数幂-导学案
- 初步设计方案询价表
- 2022年江苏省环保集团有限公司招聘笔试题库及答案解析
- 《汽车焊接技术》试卷期末理论考试含参考答案一套
- FMEA分析经典案例【范本模板】
- 2023-2023年山东省学业水平考试英语试题及答案
评论
0/150
提交评论