- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构课程设计代码
#includeiostream.h
#includestdio.h
#includemalloc.h
#define MAX 25
typedef struct
{
char data;
int weight;
int parent;
int lchild;
int rchild;
} HTNode;
typedef struct
{
char cd[MAX];
int start;
} HuffmanCode;
int main()
{
HTNode ht[2*MAX];
HuffmanCode hcd[MAX], d;
int i, k, f, l, r, n, c, s1, s2;
cout\t哈夫曼编码与译码系统\n;
cout\n请输入哈夫曼码元素个数:;
cinn;
cout请输入各个元素的结点值与权值:\n;
for(i=1;i=n;i++)
{
cout 第i个元素--\n\t结点值:;
cinht[i].data;
cout\t权 值:;
cinht[i].weight;
}
for(i=1;i=2*n-1;i++)
ht[i].parent=ht[i].lchild=ht[i].rchild=0;
for(i=n+1;i=2*n-1;i++)
{
s1=s2=32767;
l=r=0;
for(k=1;k=i-1;k++)
if(ht[k].parent==0)
if(ht[k].weights1)
{
s2=s1;
r=l;
s1=ht[k].weight;
l=k;
}
else if(ht[k].weights2)
{
s2=ht[k].weight;
r=k;
}
ht[l].parent=i;ht[r].parent=i;//得到新结点,删除l.r,将l,r的双亲域由0改为i
ht[i].weight=ht[l].weight+ht[r].weight;//i的权值等于左右孩子之和
ht[i].lchild=l; ht[i].rchild=r; //l,r为i的左右孩子
}
for(i=1;i=n;i++)
{
d.start=n+1;//start开始时指向最后,即编码结束符位置
c=i;f=ht[i].parent;//f指向结点c的双亲结点
while(f!=0)//从叶子结点开始向上回溯,知道根结点
{
if(ht[f].lchild==c) d.cd[--d.start]=0;//结点c是f的左孩子,则生成代码0
else
d.cd[--d.start]=1; //结点c是f的左孩子,则生成代码1
c=f;f=ht[f].parent;//继续向上回溯
}
hcd[i]=d;//为第i个字符编码分配空间
}
cout输出哈夫曼编码:\n;
for(i=1;i=n;i++)
{
coutht[i].data: ;
for(k=hcd[i].start;k=n;k++)
couthcd[i].cd[k];
cout\n;
}
l: cout\n请选择编码/译码/退出系统: (B/Y/E): ;
char hfm;
cinhfm;
if(hfm==e)
return 0;
else
{
switch(hfm)
{
caseb:
{
int q ;
char bs;
cout\n哈夫曼编码\n;
cout请输入字符代码: endl;
for(q=0;bs!=10;q++)
{
bs=getchar();
for(i=1;i=n;i++)
{
if (bs==ht[i].data)
for(k=hcd[i].start;k=n;k++)
couthcd[i].cd[k];
}
}
coutendl;
} break;
casey:
{
char e;
int t,u;
t=2*n-1;
cout\n哈夫曼译码\n;
cout\n请输入哈夫曼码: endl;
for(u=0;e!=10;u++)
{
if(ht[t].lchild!=0)
{
e=getchar();
if
您可能关注的文档
- 期中试卷重点题分析讲评.doc
- 星之源五年级数学上册第五六单元检测题.doc
- 朗文英语1Bch1-3复习卷.doc
- 有理数计算题158道.doc
- 昌平区2011——2012学年第二学期高一年级期末质量抽测语文试卷.doc
- 有理数的混合运算强化练习题(可用) 2.doc
- 时间状语从句5832537.doc
- 时态语态(安徽).doc
- 有理数乘方运算教案.doc
- 有理式与整式复习测试.doc
- 中国国家标准 GB 42125.11-2025测量、控制和实验室用电气设备的安全要求 第11部分:用于处理医用材料的灭菌器和清洗消毒器的特殊要求.pdf
- 《GB 42125.11-2025测量、控制和实验室用电气设备的安全要求 第11部分:用于处理医用材料的灭菌器和清洗消毒器的特殊要求》.pdf
- 《GB/T 15237-2025术语工作及术语科学 词汇》.pdf
- GB/T 15237-2025术语工作及术语科学 词汇.pdf
- GB/T 22454-2025企业建模与体系结构 企业建模构件.pdf
- 中国国家标准 GB/T 15237-2025术语工作及术语科学 词汇.pdf
- 中国国家标准 GB/T 22454-2025企业建模与体系结构 企业建模构件.pdf
- 《GB/T 22454-2025企业建模与体系结构 企业建模构件》.pdf
- 中国国家标准 GB/T 18910.64-2025液晶显示器件 第6-4部分:测试方法 带动态背光的液晶显示模块.pdf
- 《GB/T 18910.64-2025液晶显示器件 第6-4部分:测试方法 带动态背光的液晶显示模块》.pdf
文档评论(0)