2009级数据结构实验报告实验名称:实验三——哈夫曼编/解码器的实现学生姓名:陈聪捷日期:2010年11月28日1.实验要求一、实验目的:了解哈夫曼树的思想和相关概念;二、实验内容:利用二叉树结构实现哈夫曼编/解码器1
初始化:能够对输入的任意长度的字符串s进行统计,统计每个字符的频度,并建立哈夫曼树
建立编码表:利用已经建好的哈夫曼树进行编码,并将每个字符的编码输出
编码:根据编码表对输入的字符串进行编码,并将编码后的字符串输出
译码:利用已经建好的哈夫曼树对编码后的字符串进行译码,并输出译码结果
打印:以直观的方式打印哈夫曼树
计算输入的字符串编码前和编码后的长度,并进行分析,讨论哈夫曼编码的压缩效果
用户界面可以设计成“菜单”方式,能进行交互,根据输入的字符串中每个字符出现的次数统计频度,对没有出现的字符一律不用编码
程序分析存储结构二叉树templateclassBiTree{public:BiTree();始化函数(voidHuffmanTree::Init(stringInput))算法伪代码:1
初始化链表的头结点2
获得输入字符串的第一个字符,并将其插入到链表尾部,n=1(n记录的是链表中字符的个数)3
从字符串第2个字符开始,逐个取出字符串中的字符将当前取出的字符与链表中已经存在的字符逐个比较,如果当前取出的字符与链表中已经存在的某个字符相同,则链表中该字符的权值加1
TdataTlchildTrchildTparentchardatacharcode[100]charcharacterunsignedintcountboolusedNode*next如果当前取出的字符与链表中已经存在的字符都不相同,则将其加入到链表尾部,同时n++=n(tSize记录链表中字符总数,即哈夫曼树中叶子节点总数)5
创建哈夫曼树6
销毁链表源代码: