欢迎来到天天文库
浏览记录
ID:42012614
大小:73.58 KB
页数:10页
时间:2019-09-06
《哈夫曼树实验报告北京邮电大学信通院数据结构实验三哈夫曼树实验报告》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、哈夫曼树实验报告北京邮电大学信通院数据结构实验三——哈夫曼树实验报告导读:就爱阅读网友为您分享以下“北京邮电大学信通院数据结构实验三——哈夫曼树实验报告”的资讯,希望对您有所帮助,感谢您对92to.com的支持!2009级数据结构实验报告实验名称:实验三哈夫曼编/解码器的实现学生姓名:陈聪捷日期:2010年11月28日1・实验要求一.实验目的:了解哈夫曼树的思想和相关概念;二、实验内容:利用二叉树结构实现哈夫曼编/解码器1•初始化:能够对输入的任意长度的字符串s进行统计,统计每个字符的频度,并建立哈夫曼树。
2、2•建立编码表:利用已经建好的哈夫曼树进行编码,并将每个字符的编码输出。3•编码:根据编码表对输入的字符串进行编码并将编码后的字符串输出。4•译码:利用已经建好的哈夫曼树对编码后的字符串进行译码,并输出译码结果。5•打印:以直观的方式打印哈夫曼树。6•计算输入的字符串编码前和编码后的长度,并进行分析,讨论哈夫曼编码的压缩效果。7•用户界面可以设计成“菜单”方式,能进行交互,根据输入的字符串中每个字符出现的次数统计频度,对没有出现的字符一律不用编码。2.程序分析2.1存储结构二叉树template<cl
3、assT>classBiTreepublic:BiTreeQ;〃构造函数,其前序序列由键盘输入-BiTree(void);〃析构函数BiNode<T>*GetrootO;〃获得指向根结点的指针protected:BiNode<T>*root;〃指向根结点的头指针};〃声明类BiTree及定义结构BiNodeData:二叉树是由一个根结点和两棵互不相交的左右子树构成二叉树中的结点具有相同数据类型及层次关系哈夫曼树类的数据域,继承节点类型为int的二叉树classHuffmanTr
4、ee:pubIicBiTree<int>data:HCode*HCodeTable;//编码表inttSize;〃编码表中的总字符数二叉树的节点结构template<classT>structBiNode〃二叉树的结点结构{Tdata;〃记录数据Tparent;〃双亲};编码表的节点结构structHCodechardata;〃编码表中的字符charcode[100];〃该字符对应的编码};待编码字符串由键盘输入,输入时用链表存储,链表节点为structNodecharcharact
5、er;〃输入的字符unsignedintcount;//该字符的权值boolused;〃建立树的时候该字符是否使用过Node*next;〃保存下一个节点的地址};不意图:2.2关键算法分析1•初始化函数(voidHuffmanTree::Init(stringInput))算法伪代码:1•初始化链表的头结点2•获得输入字符串的第一个字符,并将其插入到链表尾部,n=l(n记录的是链表中字符的个数)3.从字符串第2个字符开始,逐个取出字符串中的字符3.1将当前取出的字符与链表中已经存在的字符逐个比较,如果当前取
6、出的字符与链表中己经存在的某个字符相同,则链表中该字符的权值加1。3.2如果当前取出的字符与链表中已经存在的字符都不相同,则将其加入到链表尾部,同时n++4.tSize=n(tSize记录链表中字符总数,即哈夫曼树中叶子节点总数)5•创建哈夫曼树6•销毁链表源代码:voidHuffmanTree::Init(stringInput)
此文档下载收益归作者所有