欢迎来到天天文库
浏览记录
ID:13203160
大小:829.00 KB
页数:28页
时间:2018-07-21
《数据结构报告c语言上机操作》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、数据结构C语言上机操作学部:信息科学与技术学部学号:指导老师:姓名:专业班级:一、实验目的熟练C言语语法及操作,运用C语言实现数据结构中的具体过程。理解数据结构在计算机中的具体形式。学习数据结构中赫夫曼变法,表和图的实现过程。二、实验环境及参考书籍MicrosoftVisualC++6.0数据结构(C语言版),程序设计基础(C语言)。三、实验内容赫夫曼编码:#include"stdio.h"#include"string.h"#include"conio.h"#include"stdlib.h"/**//*根据统计函数得到字符的种类数N和各自出现的次数,建立N个结点,由此构造一颗
2、哈夫曼树。*/#defineN30/*叶子结点数,即在信息中最多可出现30种字符*/typedefstruct{chardata;/*编码对应的字符*/intweight;/*结点的权值*/intlchild,rchild,parent;/*左右孩子及双亲的下标*/}HTNode;intStat(char*st,intcnt[],charstr[])/*统计字符信息中出现的字符种类数和各字符出现的次数*/{char*p;inti,j,k,num[27];for(i=0;i<26;i++){num[i]=0;}for(p=st;*p!=' ';p++){//*p=tolower(
3、*p);/*若字符信息中有大写字母,则将其转换成小写字母*/if(*p>='a'&&*p<='z')/**/{k=*p-96;num[k]++;}}j=0;for(i=0;i<26;i++){if(num[i]!=0){str[j]=i+96;cnt[j]=num[i];j++;}}returnj;}voidCreatHufmTree(HTNodeht[],intn)/*建立哈夫曼树*/{inti,k,m1,m2,l,r;for(i=0;i<2*n-1;i++)ht[i].lchild=ht[i].rchild=ht[i].parent=0;/*对所有结点的左右孩子及双亲指针域赋
4、空值*/for(i=n;i<2*n-1;i++){m1=m2=10000;/*m1为最小值,m2为次小值*/l=r=0;for(k=0;k<=i-1;k++)if(ht[k].parent==0&&ht[k].weight5、ht[i].weight=ht[l].weight+ht[r].weight;/*新结点的权值为两个结点的权值之和*/ht[i].lchild=l;/*权值最小的结点是新结点的左孩子*/ht[i].rchild=r;/*权值次小的结点是新结点的右孩子*/}}typedefstruct{charbits[N];/*存放哈夫曼编码的字符数组*/intstart;/*记录编码的起始位置,因为每种字符的编码长度不同*/}HCode;voidHufmCode(HTNodeht[],HCodehcd[],intn)/*利用哈夫曼树求出各字符的哈夫曼编码*/{inti,f,c,k;HCodec6、d;/*用于临时存放编码串*/for(i=0;i7、rt指向哈夫曼编码最开始字符*/hcd[i]=cd;/*将得到的第i种字符的哈夫曼编码存入hcd[i]中*/}printf("输出哈夫曼编码:");for(i=0;i
5、ht[i].weight=ht[l].weight+ht[r].weight;/*新结点的权值为两个结点的权值之和*/ht[i].lchild=l;/*权值最小的结点是新结点的左孩子*/ht[i].rchild=r;/*权值次小的结点是新结点的右孩子*/}}typedefstruct{charbits[N];/*存放哈夫曼编码的字符数组*/intstart;/*记录编码的起始位置,因为每种字符的编码长度不同*/}HCode;voidHufmCode(HTNodeht[],HCodehcd[],intn)/*利用哈夫曼树求出各字符的哈夫曼编码*/{inti,f,c,k;HCodec
6、d;/*用于临时存放编码串*/for(i=0;i7、rt指向哈夫曼编码最开始字符*/hcd[i]=cd;/*将得到的第i种字符的哈夫曼编码存入hcd[i]中*/}printf("输出哈夫曼编码:");for(i=0;i
7、rt指向哈夫曼编码最开始字符*/hcd[i]=cd;/*将得到的第i种字符的哈夫曼编码存入hcd[i]中*/}printf("输出哈夫曼编码:");for(i=0;i
此文档下载收益归作者所有