- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构上机实践报告
姓名:汪训刚 学号:
实验日期:2013年5月5日
1. 实验目的
加深对线性查找、对分查找、分块查找算法的理解;
加深对压缩理论和技术的理解;
增进对Huffman压缩编码算法的设计和编写能力;
实验内容和要求
实验内容:
试设计一算法,从包括n个元素的数组中,求最大和最小元素,并使得当n个元素为有序排列时,元素之间的比较次数仅为n-1次。
在给出的Huffman编码源程序基础上,要求画出Huffman树,求出与等长编码相比时的压缩比。
实验要求:
根据实验内容编写算法,并用 C 语言进行程序设计。
将所编程序在计算机上调试通过,并全面测试。
整理完成实验报告,包括:姓名、学号、实验日期等。
3. 程序清单
实验内容1程序:
#include stdio.h
#include malloc.h
void main()
{
int *pshuzu,m,i,j=Y,max,min,temp,N;
while((j==Y)||(j==y))
{
printf(请输入数组大小:\n);
scanf(%d,N);
printf(请输入数组元素:\n);
pshuzu=(int *)malloc(N*sizeof(int)); //pshuzu声明为一个指向数组的指针 for(m=0;mN;m++)
{
scanf(%d,pshuzu+m);
}
min=*pshuzu;
max=*pshuzu;
if(*(pshuzu)= *(pshuzu+1))
{
for (i=1;iN-1;i++)
{
if (*(pshuzu+i)=max)
max= *(pshuzu+i);
else if (*(pshuzu+i)=min)
min= *(pshuzu+i);
}
}
else
{
for (i=1;iN-1;i++)
{
if (*(pshuzu+i)=min)
min= *(pshuzu+i);
else if (*(pshuzu+i)=max)
max= *(pshuzu+i);
}
}
printf(数组中的最大值为%d\n,max);
printf(数组中的最小值为%d\n,min);
printf(数组的比较次数为%d\n,N-1);
printf(数组的最大最小值已求出,还要继续吗?(Y/N)\n);
scanf( %c,j);
printf(\n);
}
}
实验内容2程序:
#include dos.h
#include conio.h
#include stdio.h
#include stdlib.h
#include string.h
typedef struct
{unsigned int weight; //结点权值
unsigned int parent,lchild,rchild; //结点的父指针,左右孩子指针
}HTNode,*HuffmanTree; //动态分配数组存储哈夫曼树
typedef char **HuffmanCode; //动态分配数组存储哈夫曼编码表
void CreateHuffmanTree(HuffmanTree ,unsigned int*,int ); //生成哈夫曼树
void HuffmanCoding(HuffmanTree,HuffmanCode ,int ); //对哈夫曼树进行编码
void PrintHuffmanCode(HuffmanCode,unsigned int*,int); //显示哈夫曼编码
void Select(HuffmanTree,int,int,int); //在数组中寻找权值最小的两个结点
void main()
{HuffmanTree HT; //哈夫曼树HT
HuffmanCode HC
文档评论(0)