1、数据结构与算法课程设计目 录一、 前言1摘要2 数据结构与算法课程设计任务书二、实验目的三、题目-赫夫曼编码/译码器1问题描述2基本要求3测试要求4实现提示四、 需求分析-具体要求五、 概要设计六、 程序说明七、 详细设计八、 实验心得与体会2前言1摘要随着计算机的普遍应用与日益发展,其应用早已不局限于简单的数值运算,而涉及到问题的分析、数据结构框架的设计以及设计最短路线等复杂的非数值处理和操作。算法与数据结构的学习就是为以后利用计算机资源高效地开发非数值处理的计算机程序打下坚实的理论、方法和技术基础。算法与数据结构旨在分析研究计算机加工的数据对象的特性,以便选择适当的数据结构和存储结构,从而
2、使建立在其上的解决问题的算法达到最优。数据结构是在整个计算机科学与技术领域上广泛被使用的术语。它用来反映一个数据的内部构成,即一个数据由那些成分数据构成,以什么方式构成,呈什么结构。数据结构有逻辑上的数据结构和物理上的数据结构之分。逻辑上的数据结构反映成分数据之间的逻辑关系,而物理上的数据结构反映成分数据在计算机内部的存储安排。数据结构是数据存在的形式。数据结构主要介绍一些最常用的数据结构,阐明各种数据结构内在的逻辑关系,讨论其在计算机中的存储表示,以及在其上进行各种运算时的实现算法,并对算法的效率进行简单的分析和讨论。数据结构是介于数学、计算机软件和计算机硬件之间的一门计算机专业的核心课程,
3、它是计算机程序设计、数据库、操作系统、编译原理及人工智能等的重要基础,广泛的应用于信息学、系统工程等各种领域。学习数据结构是为了将实际问题中所涉及的对象在计算机中表示出来并对它们进行处理。通过课程设计可以提高学生的思维能力,促进学生的综合应用能力和专业素质的提高。2数据结构与算法课程设计任务书数据结构与算法是计算机专业重要的核心课程之一,在计算机专业的学习过程中占有非常重要的地位。数据结构与算法课程设计就是要运用本课程以及到目前为止的有关课程中的知识和技术来解决实际问题。特别是面临非数值计算类型的应用问题时,需要选择适当的数据结构,设计出满足一定时间和空间限制的有效算法。本课程设计要求同学独立
4、完成一个较为完整的应用需求分析。并在设计和编写具有一定规模程序的过程中,深化对数据结构与算法课程中基本概念、理论和方法的理解;训练综合运用所学知识处理实际问题的能力,强化面向对象的程序设计理念;使自己的程序设计与调试水平有一个明显的提高。 3二、实验目的数据结构作为一门学科主要研究数据的各种逻辑结构和存储结构,以及对数据的各种操作。因此,主要有三个方面的内容:数据的逻辑结构;数据的物理存储结构;对数据的操作(或算法) 。通常,算法的设计取决于数据的逻辑结构,算法的实现取决于数据的物理存储结构。数据结构是信息的一种组织方式,其目的是为了提高算法的效率,它通常与一组算法的集合相对应,通过这组算法集
5、合可以对数据结构中的数据进行某种操作。在当今信息时代,信息技术己成为当代知识经济的核心技术。我们时刻都在和数据打交道。比如人们在外出工作时找最短路径,在银行查询存款、通过互联网查新闻、以及远程教育报名等,所有这些都在与数据发生关系。实际上,现实世界中的实体经过抽象以后,就可以成为计算机上所处理的数据。数据结构课程主要是研究非数值计算的程序设计问题中所出现的计算机操作对象以及它们之间的关系和操作的学科。数据结构是介于数学、计算机软件和计算机硬件之间的一门计算机专业的核心课程,它是计算机程序设计、数据库、操作系统、编译原理及人工智能等的重要基础,广泛的应用于信息学、系统工程等各种领域。学习数据结构
6、是为了将实际问题中所涉及的对象在计算机中表示出来并对它们进行处理。通过课程设计可以提高学生的思维能力,促进学生的综合应用能力和专业素质的提高。通过此次课程设计主要达到以下目的: 了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;提高综合运用所学的理论知识和方法独立分析和解决问题的能力; 训练用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所应具备的科学的工作方法和作风。4三、题目-赫夫曼编码/ 译码器1. 问题描述利用赫夫曼编码进行通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。这要
7、求在发送端通过一个编码系统对待传输数据预先编码,在接收端将传来的数据进行译码(复原)。对于双工信道(即可以双向传输信息的信道),每端都需要一个完整的编/译码系统。试为这样的信息收发站编写一个赫夫曼码的编/译码系统。2. 基本要求一个完整的系统应具有以下功能:(1) I:初始化(Initialization) 。从终端读入字符集大小 n,以及 n 个字符和 n 个权值,建立赫夫曼树,并将它存于文件 hfmTree 中。(2) E:编码( Encoding) 。利用已建好的赫夫曼树(如不在内存,则从文件 hfmTree 中读入) ,对文件ToBeTran 中的正文进行编码,然后将结果存入文件 Co
8、deFile 中。(3) D:译码( Decoding) 。利用已建好的赫夫曼树将文件 CodeFile 中的代码进行译码,结果存入文件Textfile 中。以下为选做:(4) P:印代码文件(Print) 。将文件 CodeFile 以紧凑格式显示在终端上,每行 50 个代码。同时将此字符形式的编码文件写入文件 CodePrin 中。(5) T:印赫夫曼树(Tree printing) 。将已在内存中的赫夫曼树以直观的方式(比如树)显示在终端上,同时将此字符形式的赫夫曼树写入文件 TreePrint 中。3. 测试要求(1) 已知某系统在通信联络中只可能出现八种字符,其频率分别为0.05,0
9、.29,0.07,0.08,0.14,0.23,0.03,0.11,试设计赫夫曼编码。(2) 用下表给出的字符集和频度的实际统计数据建立赫夫曼树,并实现以下报文的编码和译码:“THIS PROGRAME IS MY FAVORITE”。字符 A B C D E F G H I J K L M频度 186 64 13 22 32 103 21 15 47 57 1 5 32 20字符 N O P Q R S T U V W X Y Z频度 57 63 15 1 48 51 80 23 8 18 1 16 14. 实现提示(1) 编码结果以文本方式存储在文件 Codefile 中。(2) 用户界面
10、可以设计为“菜单”方式:显示上述功能符号,再加上 “Q”,表示退出运行 Quit。请用户键入一个选择功能符。此功能执行完毕后再显示此菜单,直至某次用户选择了“Q”为止。(3) 在程序的一次执行过程中,第一次执行 I,D 或 C 命令之后,赫夫曼树已经在内存了,不必再读入。每次执行中不一定执行 I 命令,因为文件 hfmTree 可能早已建好。5四、具体要求:课程设计成果的内容必须由以下四个部分组成,缺一不可。(1) 上交源程序:学生按照实验题目的具体要求所开发的所有源程序(应该放到一个文件夹中) ;(2) 上交程序的说明文件:(保存在.txt 中)在说明文档中应该写明上交程序所在的目录,上交程
11、序的主程序文件名,如果需要安装,要有程序的安装使用说明;(3) 设计报告:(保存在 word 文档中,文件名要求: 按照 “姓名_学号_设计题目”起名,如文件名为“ 张三_XXX_赫夫曼编码 ”.doc。打印稿用 A4 纸) 。其中包括: 题目; 实验目的; 需求分析:在该部分中叙述实现的功能要求; 概要设计:在此说明每个部分的算法设计说明(可以是描述算法的流程图),每个程序中使用的存储结构设计说明(如果指定存储结构请写出该存储结构的定义); 详细设计各个算法实现的源程序,对每个题目要有相应的源程序(可以是一组源程序,每个功能模块采用不同的函数实现)。源程序要按照写程序的规则来编写。要结构清晰
12、,重点函数的重点变量、重点功能部分要加上清晰的程序注释; 调试分析测试数据,测试输出的结果,时间复杂度分析,和每个模块设计和调试时存在问题的思考(问题是哪些?问题如何解决?),算法的改进设想; 总结: 总结可以包括 : 设计过程的收获、遇到问题及解决问题过程的思考、程序调试能力的思考、对数据结构这门课程的思考、在设计过程中对数据结构课程的认识等内容。(4)考核成绩评定标准:本课程设计的评价由三部分组成,包括程序演示(50%),课程设计报告(30%),回答教师提问(20%)。1程序演示: 优 功能完善,全部测试正确,并且能够对局部进行完善。 良 功能完善,但测试欠缺。 中 功能基本完善,但程序尚
13、有部分错误。 及格 完成内存中赫夫曼编码/译码,但不涉及文件操作。 不及格 功能不完善,且程序错误较多,无法运行。2课程设计报告:61优 包括设计内容,设计思想,已经完成的任务及达到的目标,设计思路清晰、书写条理清楚,源程序结构合理、清晰,注释说明完整,有对本次课程设计的心得体会。2良 包括设计内容,设计思想,已经完成的任务及达到的目标,设计思路基本清晰、书写条理基本清楚,源程序结构合理、清晰,注释说明基本完整,有对本次课程设计的心得体会。3中 课程设计报告内容基本完整,思路较清晰,书写基本清楚,源程序结构尚可,有注释说明但不完整。4及格 课程设计报告内容基本完整,思路较差,书写尚清楚。5不及
14、格 课程设计报告内容不完整,书写没有条理。3回答教师提问:1. 优 能回答教师提出的所有问题,并完全正确,思路清晰2. 良 基本能回答教师提出的所有问题,有些小错误3. 中 基本能回答教师提出的问题,少数问题回答错误或不清楚4. 及格 能回答教师提出的问题,但较多问题回答错误或不能回答5. 不及格 基本不能回答教师提出的问题74、概要设计1) 问题分析哈夫曼树的定义1.哈夫曼树节点的数据类型定义为:typedef struct /赫夫曼树的结构体char ch;int weight; /权值int parent,lchild,rchild;htnode,*hfmtree;2)所实现的功能函数如
15、下1、void hfmcoding(hfmtree int weight; /权值int parent,lchild,rchild;htnode,*hfmtree;typedef char *hfmcode;void Select(hfmtree for(j=1;jy)*p1=y;*p2=x;else*p1=x;*p2=y;void hfmcoding(hfmtree int p1,p2;char *cd,z;if(nchoice;if(choice=I|choice=i) /初始化赫夫曼树coutn;hfmcoding(HT,HC,n);for(i=1;icode;couth;input_f
16、ile.close();output_file.open(“Textfile.txt“);if(!output_file)couth; couthendl;input_file.close();cout“译码结束,字符已经存入 Textfile.txt 文件中!“endl;else if(choice=Q|choice=q) /退出程序 exit(0);else /如果选了选项之外的就让用户重新选择cout“您没有输入正确的步骤,请重新输入!“endl;coutendl;return 0;146调试分析编码、译码15、退出7实验心得与体会在我自己课程设计中,就在编写好源代码后的调试中出现了不少
17、的错误,遇到了很多麻烦及困难,我的调试及其中的错误和我最终找出错误,修改为正确的能够执行的程序中,通过分析,我学到了:在定义头文件时可多不可少,即我们可多写些头文件,肯定不会出错,但是若没有定义所引用的相关头文件,必定调试不通过;在执行译码操作时,不知什么原因,总是不能把要编译的二进制数与编译成的字符用连接号连接起来,而是按顺序直接放在一起,视觉效果不是很好。还有就是,很遗憾的是,我们的哈夫曼编码/译码器没有像老师要求的那样完成编一个文件的功能,这是我们设计的失败之处。通过本次数据结构的课程设计,我学习了很多在上课没懂的知识,并对求哈夫曼树及哈夫曼编码/译码的算法有了更加深刻的了解,更巩固了课堂中学习有关于哈夫曼编码的知识,真正学会一种算法了。当求解一个算法时,不是拿到问题就不加思索地做,而是首先要先对它有个大概的了解,接着再详细地分析每一步怎么做,无论自己以前是否有处理过相似的问题,只要按照以上的步骤,必定会顺利地做出来。这次课程设计,我在编辑中犯了不应有的错误,设计统计字符和合并时忘记应该怎样保存数据,对文件的操作也很生疏。在不断分析后明确并改正了错误和疏漏,我的程序有了更高的质量。