- 1、本文档共21页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- .高三语文·文化经典孟子阅读与训练一.doc
- 00031心理学笔记与的的练习题.doc
- 01 海德格尔路通过现象学到存在之思.doc
- 01年到10年申论的的答案1.doc
- 01陈公弼传 苏轼11江苏1.doc
- 0212外国文学上西南大学复习的思考题.doc
- 02转换层模板技术交底.doc
- 03 考录的方案.doc
- 03708选择题.doc
- 04中华德育故事故事梗概260集.doc
- 温州乐成寄宿中学2023年高三第二次模拟考试语文试卷含解析.doc
- 湖南省浏阳市第二中学2022-2023学年高三第一次调研测试语文试卷含解析.doc
- 甘肃省张掖市高台县重点名校2024年中考一模英语试题含答案.doc
- 甘肃省会宁县第四中学2024届高三下学期第六次检测语文试卷含解析.doc
- 滁州市重点中学2024届高三第四次模拟考试语文试卷含解析.doc
- 福建省福州市仓山区福建师范大学附属中学2023届高考冲刺模拟英语试题含解析.doc
- 福建省平和县一中2022-2023学年高考压轴卷语文试卷含解析.doc
- 湖南省长沙市一中、湖南师大附中2023年高三英语第一学期期末学业质量监测模拟试题含解析.doc
- 监狱警察职业道德培训课件.pptx
- 福建省漳州市平和一中、南靖一中等五校2023年高三第六次模拟考试语文试卷含解析.doc
文档评论(0)