01109143朱子骏.docxVIP

  1. 1、本文档共21页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
01109143朱子骏

《数据结构》实验报告题目:_ 哈夫曼树的实现学号:_________姓名:_朱子骏__________教师:___李香菊________东南大学成贤学院计算机系2012年4月23日huffman_tree.h的代码:#ifndef __HUFFMAN_TREE_H__#define __HUFFMAN_TREE_H__#include string.h// 串类#include huffman_tree_node.h// 哈夫曼树结点类模板// 哈夫曼树类模板template class CharType, class WeightTypeclass HuffmanTree{protected:// 哈夫曼树的数据成员:HuffmanTreeNodeWeightType *nodes;// 存储结点信息,nodes[0]未用CharType *LeafChars;// 叶结点字符信息,LeafChars[0]未用String *LeafCharCodes;// 叶结点字符编码信息,LeafCharCodes[0]未用int curPos;// 译码时从根结点到叶结点路径的当前结点int num;// 叶结点个数//辅助函数模板:void Select(int cur, int r1, int r2);// nodes[1 ~ cur]中选择双亲为0,权值最小的两个结点r1,r2void CreatHuffmanTree(CharType ch[], WeightType w[], int n);// 由字符,权值和字符个数构造哈夫曼树public:// 哈夫曼树方法声明及重载编译系统默认方法声明:HuffmanTree(CharType ch[], WeightType w[], int n);// 由字符,权值和字符个数构造哈夫曼树virtual ~HuffmanTree();// 析构函数模板String Encode(CharType ch);// 编码LinkListCharType Decode(String strCode);// 译码HuffmanTree(const HuffmanTreeCharType, WeightType copy);// 复制构造函数模板HuffmanTreeCharType, WeightType operator=(const HuffmanTreeCharType, WeightType copy);// 重载赋值运算符};// 孩子兄弟表示哈夫曼树类模板的实现部分template class CharType, class WeightTypevoid HuffmanTreeCharType, WeightType::Select(int cur, int r1, int r2)// 操作结果:nodes[1 ~ cur]中选择双亲为0,权值最小的两个结点r1,r2{r1 = r2 = 0;// 0表示空结点for (int pos = 1; pos = cur; pos++){// 查找树值最小的两个结点if (nodes[pos].parent != 0) continue;// 只处理双亲不为0的结点if (r1 == 0){// r1为空,将pos赋值给r1r1 = pos;}else if (r2 == 0){// r2为空,将pos赋值给r2r2 = pos;}else if(nodes[pos].weight nodes[r1].weight){// nodes[pos]权值比nodes[r1]更小,将pos赋为r1r1 = pos;}else if (nodes[pos].weight nodes[r2].weight){// nodes[pos]权值比nodes[r2]更小,将pos赋为r2r2 = pos;}}}template class CharType, class WeightTypevoid HuffmanTreeCharType, WeightType::CreatHuffmanTree(CharType ch[], WeightType w[], int n)// 操作结果:由字符,权值和字符个数构造哈夫曼树{num = n;// 叶结点个数int m = 2 * n - 1;// 结点个数nodes = new HuffmanTreeNodeWeightType[m + 1];// nodes[0]未用LeafChars = new CharType[n + 1];// LeafChars[0]未用LeafCharCodes = new String[n + 1];// LeafCharCodes[0]未用int

文档评论(0)

317960162 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档