- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Huffman编解码问题 讲解
2.5 Huffman编码问题
实验四一一题目 2:
利用二叉树结构实现哈夫曼编 /解码器。
基本要求:
1、 初始化(lnit):能够对输入的任意长度的字符串 s进行统计,统计每个字符的频度, 并 建立哈夫曼树
2、 建立编码表(CreateTable):利用己经建好的哈夫曼树进行编码,并将每个字符的 编 码输岀。
3、 编码(Encoding):根据编码表对输入的字符串进行编码,并将编码后的字符串输
出。
4、 译码(Decoding):利用己经建好的哈夫曼树对编码后的字符串进行译码, 并输岀译码 结果。
5、 打印(Print):以直观的方式打印哈夫曼树(选作)
6、 计算输入的字符串编码前和编码后的长度,并进行分析,讨论赫夫曼编码的压 缩效 果。
7、 可采用二进制编码方式(选作)
实验讲解:
Huffman编解码的实验按照模块化分,可以划分成如下部分:
统计输入的字符串中字符频率
创建Huffman树
打印Huffman树
创建Huffman编码表
对输入的字符串进行编码并输岀编码结果
对编码结果进行解码,并输岀解码后的字符串
最后编写测试函数,测试上述步骤的正确性。
根据模块化分,设计 Huffman的存储结构如下:
1) Huffman树的结点结构struct
HNode {
int weight; 〃结点权值
jnt pare nt; //双亲指针
int LChild ; 〃左孩子指针
int RChild ;//右孩子指针
};
data
code
0
Z
100
1
C
101
2
B
11
3
A
0
202)编码表结
20
点结构(如
右图2-6所
示)
struct HCode { char data; char codeuoo】;
};
图2-6 Huffman 树编码结构
3)Huffman类结构classHuffma n
private :
HNode * HTree ;
//Huffman 树
HCode * HCodeTable ;
//Huffman 编码
char str [1024]; char
表
leaf[256]; int a[256];
//输入的原始字符串
//叶子
public :
节点对应的字符 //
记录每个
岀现字符的个数
{
int n;
//叶子节点数
void init();
//初始化
void CreateHTree(); 〃仓曜 huffman 树 voidSelectMin(int x, int y, int s, int e
void CreateCodeTableo; 〃 创建编码表
void Encode(char *d); 〃编码
void Decode(char *s, char *d); 〃解码
void print(int i, int m); 〃打印 Huffman 树 ? Huffman();
根据实验要求,分步骤实现如下:
步骤1 :统计输入的字符串中字符频率
式 计效Huffman编码的第一步需要使用字符岀现的频率作为输入,本实验使用从键盘输入的方 进行,需要的解决得问题有 2个:一是输入的字符串中间有空格如何处理?二是如何使统 率更高? 例如: str[1024];
式 计效
cinstr;
上述代码运行后输入字符串,但 cmstr遇到空格就停止本次读取,所以我们需要使
用其它的方法来进行输入,即需要使用 cm. get()函数进行字符串读取。 get()方法每调
用一次,读取一个字符,该字符的 码作为返回值返回,换行回车等控制字符也当
作普通字符
进行读取,因此需要指定结束读取的标志字符,才能停止get()函数的循环调用。 本实验中可以将字符读取和统计结合在一起进行。示例代码如下:intnNum【256]= {0};int ch =
进行读取,因此需要指定结束读取的标志字符,才能停止
get()函数的循环调用。 本实验中
可以将字符读取和统计结合
在一起进行。示例代码如下:
int
nNum【256]= {0};
int ch =
cin .geto; int i=o; while(( ch匸
V) (cm= n ){
nN um【ch】++; str【i++] = ch; ch = ci n.geto;
//记录每一个字符出现的次数
//统计字符岀现的次数 //记录原始字符串〃 读取下一个字符
str【i】=, o’
其中,整型数组变量 nNum 用来记录每一个字符岀现的次数(若该字符未岀现,则 对应的nNum〔ch]的值为。),可以把读取的字符ch的ASCII码当成,当 ch 岀现时,nNum【ch】自
动加一。
当然,数组nNum 中的等于零的字符会有很多,不方便后续 建,因此可
h
您可能关注的文档
最近下载
- 山东省烟台市蓬莱实验初级中学2024-2025学年度第一学期9年级道德与法治素养形成期中测试(图片版,含答案).docx VIP
- 全国2025年10月自考00185《商品流通概论》真题及答案.docx VIP
- 2023年4月 自考 06056 心理学史 试题.pdf VIP
- 涉案财物管理系统V2.0T-用户使用说明书.pdf VIP
- 2025年网络安全等级测评师(中级)考核试题与答案.pdf VIP
- 电梯学徒安全培训记录课件.pptx VIP
- 公务员制度专题二.ppt VIP
- tc官网软件资源中文产品手册voicetone.pdf VIP
- 路灯售后服务方案及措施.docx VIP
- 河北省部分高中2024-2025学年高一上学期11月阶段性测试语文试卷(含答案).docx VIP
原创力文档


文档评论(0)