最近完成了数据结构课程设计,被分到的题目是《哈夫曼编码和解码》,现在在这篇博文里分享一下自己的成果。 我在设计时,在网上参考了很多老师和前辈的算法和代码,向他们表示感谢!他们的成果给了我很多启示和帮助。另外,自己的成品中也还有很多不完善的地方,欢迎批评指正。 课题:哈夫曼编码 ...
添加上解码。 解码要求: 根据输入的 字符串输出相对应的字符。 解码过程: node p,p作为移动指针,在已经构造好的哈夫曼树中进行移动。移动规则,遇到 向左子树移动,遇到 向右子树移动。 输入 字符串s 可以用string也可以用char数组,在此使用string ,求出串的长度s.size . 进入循环,进行相应判断以及输出。关键代码: 给出全部代码以及运行实例: View Code 输入: ...
2015-11-22 16:38 0 2019 推荐指数:
最近完成了数据结构课程设计,被分到的题目是《哈夫曼编码和解码》,现在在这篇博文里分享一下自己的成果。 我在设计时,在网上参考了很多老师和前辈的算法和代码,向他们表示感谢!他们的成果给了我很多启示和帮助。另外,自己的成品中也还有很多不完善的地方,欢迎批评指正。 课题:哈夫曼编码 ...
添加注释版本: View Code 未加注释清爽版: 测试样例: 输入: 输入: View Cod ...
//由于编译器版本原因strcpy出现不安全原因,导致无法运行,后使用strcpy_s给予拷贝长度得到解决;把“==”写成“=”导致报错;/*输入字符串统计字符个数(权值)int Cre ...
这是我的第一篇博客,希望大神们批评指正。 首先介绍以下什么是哈夫曼树(来自百度百科) 哈夫曼树─即最优二叉树,带权路径长度最小的二叉树,经常应用于数据压缩。 在计算机信息处理中,“哈夫曼编码”是一种一致性编码法(又称“熵编码法”),用于数据的无损耗压缩。这一术语是指使用一张特殊的编码表将源字符 ...
本代码流程: 随机输入一段字符串--->根据输入字符串得到每个字符权重(频数)并输出--->得到每个字符对应哈夫曼编码并输出--->输入一段哈夫曼编码--->利用每个字符对应的哈夫曼编码来解码 技术支持: 1.如何得到每个自负权重,上上个博客,网址如下: https ...
哈夫曼(Haffman)树(最优树) 定义: 给定n个权值作为n个叶子结点,构造一棵二叉树,若该树的带权路径长度达到最小,称这样的二叉树为最优二叉树,也称为哈夫曼树(Huffman Tree)。哈夫曼树是带权路径长度最短的树,权值较大的结点离根较近。 构造过程: 以 1,7,3,4,9,8 ...
目录 一、什么是哈夫曼树(Huffman Tree) 1.1 哈夫曼树的定义 二、哈夫曼树的构造 2.1 哈夫曼树的特点 三、哈夫曼编码 3.1 使用二叉树编码 3.2 使用哈夫曼树编码 ...
一、哈夫曼树的概念和定义 什么是哈夫曼树? 让我们先举一个例子。 判定树: 在很多问题的处理过程中,需要进行大量的条件判断,这些判断结构的设计直接影响着程序的执行效率。例如,编制一个程序,将百分制转换成五个等级输出。大家可能认为这个程序很简单,并且很快 ...