哈夫曼编译树.pdf
《哈夫曼编译树.pdf》由会员分享,可在线阅读,更多相关《哈夫曼编译树.pdf(12页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、哈夫曼编码译码器实验报告2011 级网络工程1 班姓名:翁轩轩学号:41109040116 完成日期:2013.01.03 1需求分析(1)输入字符和权值;(2)输出哈夫曼树及哈夫曼编码;(3)程序可以根据字符使用的频率设计哈夫曼编码;(4)测试数据:2概要设计本程序的数据类型定义为typedef struct unsigned int weight;unsigned int parent,lchild,rchild;HTNode,*HuffmanTree;typedef char*HuffmanCode;所实现的功能函数如下void initHuffmanTree();/选择初始化哈夫曼树的
2、方式int openfileInit();/通过打开的data.txt文件初始化哈夫曼树该文件是为了测试数据2 包涵 26 个字符int inputInit();/通过手动输入字符初始化哈夫曼树int HuffmanCoding(int*w);/初始化哈夫曼数,按照哈夫曼规则建立二叉树。此函数块调用了 Select()函数。void Select(int j,int&s1,int&s2);/选择 parent为 0,且 weight 最小的两个节点序号为 s1,s2 void encoding();/选择哈夫曼编码方式void openfileEnco();/通过打开文件encode.txt的
3、方式进行编码void inputEnco();/通过手动输入的方式进行编码void decode();/选择译码方式void openfileDeco();/通过打开文件CodeFile.txt的方式进行译码void inputDeco();/通过手动输入的方式进行译码void dispHT(HuffmanTree nodeRoot,int level);/以缩进方式输出哈夫曼树直观图主函数字符a v e s f 频度1 2 3 4 2 主函数主要设计的是一个分支语句,让用户挑选所实现的功能。如图所示:3详细设计4调试分析在写程序与调试的过程中,发现自己对于函数的调用与参数的传递的方面还是存在
4、很多问题,从参数的类型等等方面都出现了很多问题。关于这个程序的要求比较复杂,刚开始做的时候没有任何思路,最后分模块一点一点的进行。在输出树的直观图的问题上一开始困扰了我很久,后来想到用一个level记录层数,以缩进的方式分层显示,解决了这个问题。在调试过程中,出现了很多次明明建立了文件却发现未存入数据的情况,为此我多次进行调试,发现是打开文件的操作放在了循环体内部导致数据无法写入。整体而言,整个程序主要使用了HuffmanCoding()的方式进行哈夫曼编码,在encoding()里面用了字符串的匹配进行译码,在decode()里进行了重新遍历树的过程,在算法的效率以及如何更为节省空间的存储数
5、据上都要进一步改进。5用户使用说明本程序适应环境为VC6.0 在输入字符及使用频率后可以输出哈夫曼树(以缩进方式输出哈夫曼树直观图)及哈夫曼编码6测试结果initHuffmanTree();初始化哈夫曼树HuffmanCoding()构造哈夫曼树编码调用Encoding()译码调用Decode()dispHT()打 印 哈 夫 曼树Select()供HuffmanCoding()调用文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7
6、Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A
7、2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6
8、H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10
9、Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N
10、2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6
11、V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J
12、10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B
13、4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:C
14、C6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA
15、9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD
16、7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码
17、:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5
18、HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S57附录#include#include#include /*定义赫夫曼树结点的结构体变量,存放结点的权值、字符、双亲、坐孩子和右孩子*/typ
19、edef struct int weight;char ch;/增加一个域用于存放该节点的字符 int parent,lchild,rchild;HTNode,*HuffmanTree;typedef char*HuffmanCode;/指向赫夫曼编码的指针/*本程序用到的函数原型*/void welcome();/打印操作选择界面void HuffmanCoding(HuffmanTree&,char*,int*,int);/建立赫夫曼树的算法void select(HuffmanTree HT,int j,int*s1,int*s2);/从目前已建好的赫夫曼树中选择parent 为 0 且
20、 weight 最小的两个结点void Init();/输入 n 个字符及其对应的权值,根据权值建立哈夫曼树void Coding();/编码void Decoding();/译码void Print_code();/打印译码好的代码文件void Print_tree();/以凹凸表形式打印哈夫曼树int Read_tree(HuffmanTree&);/从文件中读入赫夫曼树void find(HuffmanTree&HT,char*code,char*text,int i,int m);/译码时根据01 字符串寻找相应叶子节点的递归算法文档编码:CC6V6H8I7R5 HA9J10Q7Z1K
21、9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5
22、文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I
23、7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z
24、1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2
25、S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H8I7R5 HA9J10Q7Z1K9 ZD7B4N2A2S5文档编码:CC6V6H
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 哈夫曼 编译
限制150内