- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构实验报告-霍夫曼编码
院 系:计 算 机 学 院
实验课程:数据结构实验
实验项目:实验五 霍夫曼编码/译码
指导老师:
开课时间:
专 业:计算机类
班 级:
学 生:
学 号:
实验五 霍夫曼编码/译码
综设实验题目
霍夫曼编码/译码
中文摘要
本实验是利用霍夫曼编码这一经典的数据编码方式来实现一个编码和解码的软件,实现了对指定文本的压缩功能,和对被压缩过的文件进行解压缩,恢复为原来的文件。
关键词
霍夫曼编码 压缩 C++
前言
实验目的:利用霍夫曼编码进行通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。这要求在发送端通过一个编码系统对待传输数据预先编码,在接收端将传来的数据进行译码(复原)。对于双工信道(即可以双向传输信息的信道),每端都需要一个完整的编/译码系统。
实验意义:方便对通讯网络或数据传输中对数据进行压缩,减少数据所占用的资源空间。
实验内容:主要是初始化霍夫曼树、编码、解码。。
实验设计
由于该实验主要涉及到树这一存储结构,因此整个实验的关键点便在于对树这个数据结构的建立和操作上。
这个霍夫曼树主要有以下功能:由树转化成字符和编码的映射表、保存映射表、获取树的根节点、初始化树、利用映射表对文本进行编码、利用映射表对压缩过的文本进行解压缩,还有打印树的内容。
实验实现
主要功能模块有:由树转化成字符和编码的映射表、保存映射表、获取树的根节点、初始化树、利用映射表对文本进行编码、利用映射表对压缩过的文本进行解压缩,还有打印树的内容。
由树转化成字符和编码的映射表是getCode()函数,代码如下:
void Huffman::getCode() {
stack pairnode*, string s;
s.push(make_pair(root, 0));
pairnode*, string temp;
while (!s.empty()) {
temp = s.top();
s.pop();
if (temp.first-lchild == NULL temp.first-rchild == NULL) {
code[temp.first-data] = temp.second;
code_reverse[temp.second] = temp.first-data;
continue;
}
if (temp.first-lchild != NULL) s.push(make_pair(temp.first-lchild, temp.second + 0));
if (temp.first-rchild != NULL) s.push(make_pair(temp.first-rchild, temp.second + 1));
}
return;
}
这个函数是对树进行前序遍历,每次访问到叶子节点时就保存这时的编码串和叶子结点所表示的字符。这样就获取到所有字符和它的编码串的对应关系了,这个对应关系保存在code和code_reverse这两个哈希表中。
保存映射表是saveCode()函数,代码如下:
void Huffman::saveCode() {
ofstream out(hfmTree);
for (int i = 0; i charsize; i++)
out charset[i] code[charset[i]] endl;
return;
}
保存这个表的方法就是将其写入到文件hfmTree中,可以供下次运行的时候继续使用。
获取树的根节点是getRoor()函数,代码如下:
node* Huffman::getRoot() {
return root;
}
直接返回根节点。
初始化树是init()函数,代码如下:
void Huffman::init() {
ifstream in(hfmTree);
int i = 0;
while (!in.eof()) {
in charset[i];
in code[charset[i]];
}
in.close();
return;
}
void Huffman::init(char set[], int frequent[], int len) {
priority
您可能关注的文档
最近下载
- 19-4WREE6V32-22G24K31F1V-比例阀 最详细说明书.pdf
- 2024—2025学年上海市宝山区六年级(五四学制)上学期期中语文试卷.doc VIP
- 核医学科工程项目管理重点与难点.pptx
- 2025吉林长春市总工会公招聘工会社会工作者(107人)招聘笔试备考题库及答案解析.docx VIP
- 非煤矿山岗位安全操作作业规程全套.doc VIP
- (正式版)DB61∕T 1486.8-2021 《设施茄果类蔬菜水肥一体化技术规范 第8部分:辣椒基质栽培》.docx VIP
- (正式版)DB61∕T 1486.8-2021 《设施茄果类蔬菜水肥一体化技术规范 第8部分:辣椒基质栽培》.pdf VIP
- 《光伏玻璃工艺讲解》课件.ppt VIP
- 迅达扶梯9300ae产品介绍.pdf VIP
- SL747-2016采矿业建设项目水资源论证导则.pdf VIP
原创力文档


文档评论(0)