- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
哈夫曼编码及译码系统
通达学院 算法与数据结构程序设计 题 目: 哈夫曼编码和译码系统 业 学 生 姓 名 班 级 学 号 指 导 教 师 指 导 单 位 日 期 教师评语 同学出勤率(满勤、较高、一般,较低),学习态度(端正、较端正、一般、较差),程序设计基础(好、较好、一般、较差),演示程序(已经、没有)达到了基本要求,算法设计(好、较好、一般),界面友好程度(好、较好、一般),答辩过程中回答问题(准确、较准确、错误率较高),撰写报告格式(规范、一般)、内容(丰满、简单)、表述(清晰、一般、不清楚),(圆满、较好、基本)完成了课题任务。 教师签名: 年 月 日 成绩评定 备 注 一、题目要求: 题 目 :哈夫曼编码和译码系统 基本要求: (1) 能输入字符集和各字符频度建立哈夫曼树; (2) 产生各字符的哈夫曼编码,并进行解码。 提高要求: (1) 能设计出简捷易操作的窗口界面; (2) 编码和译码存储在文件中。 二、需求分析: 2.1基本思想 根据,哈夫曼的定义,一棵二叉树要使其带权路径长度最小,必须使权值越大的叶子结点越靠近根结点,而权值越小的叶子结点越远离根结点.依据这个特点便提出了哈夫曼算法,其基本思想是: 初始化:由给定的n个权值{w1, w2,…, wn}构造n棵只有一个根结点的二叉树,从而得到一个二叉树集合F={ T1,T2,…,Tn}; 选取与合并:在F中选取根结点的权值最小的两棵二叉树分别作为左、右子树构造一颗新的二叉树,这棵新二叉树的根结点的权值为其左、右子树根结点的权值之和; 删除与加入:在F中删除作为左、右子树的两棵二叉树,并将新建立的二叉树加入到F中; 重复(2)、(3)两步,当集合F中只剩下一棵二叉树时,这棵二叉树便是哈夫曼树. 2.2存储结构 在由哈夫曼算法构造的哈夫曼树中,非叶子结点的度均为2,根据二叉树的性质可知,具有n个叶子结点的哈夫曼树共有2n-1个结点,其中有n-1个非叶子结点,它们是在n-1次的合并过程中生成的.为了便于选取根结点权值最小的二叉树以及合并操作,设置一个数组HuffmanNode[2n-1]保存哈夫曼树中各结点的信息,数组元素的结点结构如图所示. weight parent lchild rchild inf 图 哈夫曼树的结点结构 其中: weight:权值域,保存该结点的权值; Lchild:指针域,保存该结点的左孩子结点在数组中的下标; Rchild:指针域,保存该结点的右孩子结点在数组中的下标; parent:指针域,保存该结点的双亲结点在数组中的下标. 三、概要设计: 1.我首先创建了两个结构体HTNode和Node,分别来记录哈弗曼树各节点的信息以及叶子节点的信息。 建立六个成员函数,如下图所示: 各功能函数实现如下功能: 1、void CreateWeight(){......} 作用:产生叶子结点的字符和权值。 2、void CreateHuffmanTree(){......} 作用:创建HuffmanTree。 3、void CrtHuffmanNodeCode(){......} 作用:生成叶子结点的编码 4、void CrtHuffmanCode(){......} 作用:生成所有字符的编码 void TrsHuffmanTree( ){......} 作用:解码 6、主函数main() 四、详细设计 void CreateWeight(char ch[],int *s,WeightNode CW,int *p) 其中形参分别表示: char ch[]//存放用户输入的字符串 int *s//字符串ch[]的长度 WeightNode CW//存放叶子节点的信息 int *p//叶子节点的个数 核心功能: 函数通过定义三个变量i,j,k,来控制三个循环,主要是为了遍历字符串,找出叶子节点的字符与权值信息。 void CreateHuffmanTree(Huffman ht,WeightNode CW,int n) 形参表示: Huffman ht//Huffman的一个对象ht WeightNode CW//权值大小 int n//叶子节点的个
您可能关注的文档
- 化工大学设计.doc
- 北京xxx公司厂房加层改造施组方案.doc
- 北京SOHO现代城施组方案方案.doc
- 化工课程设计万吨每涠洲原油常压塔工艺计算.doc
- 北交自动控制原理实验报告及仿真.doc
- 动画大学课程设计.doc
- 北京体育大学机电施组方案.doc
- 北京中堂四合院主题酒店网络营销策略分析及建议新.doc
- 加油站客户信息管理系统课程设计.doc
- 北京大学《MBA场营销管理》原版教学笔记.doc
- 2025年航空维修人才需求结构报告.docx
- 2025年农村电商人才引进机制与激励机制设计报告.docx
- 2025年无人机测绘数据处理技术优化与智能交通管理应用报告.docx
- 2025年新能源充电桩技术路线及发展方向报告.docx
- 2025年工业互联网安全应急响应机制建设与处置工业区块链安全报告.docx
- 2025年稀土新材料行业产业政策解析报告.docx
- 2025年植物基肉制品行业市场渗透率提升与消费接受策略.docx
- 2025年图书馆行业政策环境分析报告.docx
- 2025年生物制造技术在医药中间体细胞工程报告.docx
- 2025年工业互联网标识解析应用场景拓展创新与价值实现报告.docx
有哪些信誉好的足球投注网站
文档评论(0)