数据结构与算法课程设计报告书.docx
数据结构与算法课程设计一、课程设计的目的、要求和任务本课程设计是为了配合数据结构与算法课程的开设,通过设计完整的程序,使学生掌握数据结构的应用、算法的编写等基本方法。1. 课程的目的1使学生进一步理解和掌握课堂上所学各种基本抽象数据类型的逻辑结构、存储结构和操作实现算法,以与它们在程序中的使用方法。2使学生掌握软件设计的基本容和设计方法,并培养学生进行规化软件设计的能力。3使学生掌握使用各种计算机资料和有关参考资料,提高学生进行程序设计的基本能力;2. 课程的基本要求与任务1巩固和加深对数据结构基本知识的理解,提高综合运用课程知识的能力。2培养学生自学参考书籍,查阅手册、图表和文献资料的能力。3通过实际课程设计,初步掌握简单软件的分析方法和设计方法。4了解与课程有关的工程技术规,能正确解释和分析实验结果。5题目具有足够的工作量。二、课程设计的一般步骤1划分课程设计小组:由不超过3 名同学组成一个课程设计小组,自愿组队。2选题与搜集资料:每个课程设计小组在参考选题中选择课题,并保证每人一题。3分析与概要设计:根据搜集的资料,进行程序功能与数据结构分析,并选择合适的数据结构、并在此基础上进行实现程序功能的算法设计。3程序设计:运用掌握C/C+语言编写程序,实现所有程序的各个模块功能。4调试与测试:调试程序,并记录测试情况。5完成课程设计报告。6验收与评分:指导教师对每个同学的开发的系统进行综合验收。三、任务完成形式1. 完整的软件系统最终必须向指导老师提交完整的程序源代码<.c 和.cpp 以与.h 为后缀的文件>、数据文件以与使用说明文件等。源代码文件要特别注意编程规、代码风格,关键代码需有合理的注释,不含任何无用代码;数据文件要求有一定数量的"真实"数据如对于记录文件,需要有 5 条以上记15 / 15录; 使用说明文件的第一行,需要给出设计者的学号、,后面为其它说明。2. 课程设计报告报告总体上主要包括以下几个部分,封面、目录、课程设计报告正文、使用说明、参考文献。其中课程设计报告正文<12-20 页之间,8000 字以上>,书写规,应包括如下 8 个部分:1问题描述:描述要求编程解决的问题。2功能要求:给出程序要达到的具体的要求。3算法思想:描述解决相应问题算法的设计思想。4模块划分:描述所设计程序的各个模块即函数功能。5数据结构:给出所使用的基本抽象数据类型,所定义的具体问题的数据类型,以与新定义的抽象数据类型。6核心源程序:给出核心算法源代码,要求有充分的注释语句,至少要注释每个函数参数的含义和函数返回值的含义。7测试数据:设计测试数据,或具体给出测试数据。要求测试数据能全面地测试所设计程序的功能。8测试情况与结果分析:给出程序的测试情况,并分析运行结果。四、成绩评定标准学生成绩以优、良、中、与格和不与格5 个等级评定。其中:1学生编写的实际软件和运行结果,占总成绩 45%;2设计报告,占总成绩 45%。3小组合作情况,占总成绩的 10%。该部分由指导教师进行现场口试,依据表现给分。只有程序验收通过后,才能按以下方法核定本次课程设计的总成绩。以下几点是决定总成绩的关键因素:(1) 考勤、纪律、实验室卫生(2) 工作量代码量、功能多少、难度(3) 所用到的关键技术(4) 实用性、创新(5) 代码书写规性(6) 程序界面美观、新技术运用得当(7) 个人答辩与小组合作情况 以下几种情形认定为成绩不合格:(1) 未能独立完成设计或概念不清;(2) 有效代码总量不足 1000 行<不含自动生成代码>;(3) "管理系统"类课题中使用现有数据库系统如access,SQL Server 等;(4) 课程设计报告或源代码有抄袭行为;(5) 3 次<含>以上点名未到;(6) 不遵守实验室规章制度,或不按要求完成实验室卫生工作。五、附课程设计题目1可另选题目,经指导老师认可后正式作为课程设计题目。2 数据结构课程设计参考题目1. 文件查重系统问题描述抄袭检查越来越成为一种重要的需求。本问题要求,从文件中读入两个文件,比较其雷同字句的数目。并给出详细对照。当两字符串中连续相同字符的个数达到一定数目例如 20 字>可视为雷同。也可按照相同字符占句子长度的比例来检测雷同。基本功能统计不同文件的雷同字段数,字段总长度,雷同字段比例。测试数据可自己定义。实现提示程序运行后首先要求用户给出制定的两个文件。高级要求建立文件库,对新的文件检测该文件与库中哪些文件雷同,并给出相应的比例。2. 课程设计案例管理系统收集各本课程的题目案例,每个案例包括 问题描述、基本功能要求、测试数据集、高级或扩展要求、课题实现源代码包、课程设计报告、评语等各部分。基本功能<1>.案例导入或录入 <2>.展示问题 <3>展示案例结果<4>案例查询<5>单问题多解决方案入库的处理3. 约瑟夫环问题描述约瑟夫Joeph问题的一种描述是:编号为 1,2, ,n 的 n 个人按顺时针方向围坐一圈,每人持有一个密码正整数。一开始任选一个正整数作为报数上限值m,从第一个人开始按顺时针方向自 1 开始顺序报数,报到 m 时停止报数。报m 的人出列,将他的密码作为新的m 值, 从他在顺时针方向上的下一个人开始重新从1 报数,如此下去,直至所有人全部出列为止。试设计一个程序求出出列顺序。基本要求利用单向循环链表存储结构模拟此过程,按照出列的顺序印出各人的编号。测试数据m 的初值为 20;密码:3,1,7,2,4,8,4正确的结果应为 6,1,4,7,2,3,5。实现提示程序运行后首先要求用户指定初始报数上限值,然后读取各人的密码。设 n30。*4. 长整数运算问题描述设计一个程序实现两个任意长的整数求和运算。基本要求利用双项循环链表实现长整数的存储,每个结点含一个整型变量。任何整型变量的围是-215-1215-1。输入和输出形式:按中国对于长整数的表示习惯,每四位一组,组间用逗号隔开。测试数据10;0;应输出"0"。2-2345,6789;-7654,3211;应输出"-1,0000,0000"。3-9999,9999;1,0000,0000,0000;应输出"9999,0000,0001"。41,0001,000;-1,0001,0001;应输出"0"。51,0001,0001;-1,0001,0000;应输出"1"。实现提示1每个结点中可以存放的最大整数为215-1=32767,才能保证两数相加不会溢出。但若这样存,即相当于按 32768 进制数存,在十进制数与 32768 进制数之间的转换十分不方便。故可以在每个结点中仅存十进制数的 4 位,即不超过 9999 的非负整数,整个链表视为万进制数。2可以利用头结点数据域的符号代表长整数的符号。用其绝对值表示元素结点数目。相加过程中不要破坏两个操作数链表。两操作数的头指针存于指针数组中是简化程序结构的一种方法。不能给长整数位数规定上限。选作容修改上述程序,使它在整型量围是-2n-12n-1的计算机上都能有效地运行。其中,n 是由程序读入的参量。输入数据的分组方法可以另行规定。5. 多项式链式存储结构与其代数运算问题描述设计并建立一个链式存储分配系统来表示和操作多项式。为了避免对零和非零多项式进行不同的处理,使用带头结点的循环链表。为了充分利用多项式中不再使用的结点,维护一个可用空间表avail,把不再使用的多项式的结点链入其中。当需要一个新结点时,就查看这个单链表 avail。如果表非空,那么可以使用它的一个结点。只有当该表为空时,才使用动态存储分配来创建新结点。基本要求设计多项式的存储结构,编写并测试下列函数:a>get_node 和 ret_node,从/向可用空间表申请和插入一个多项式结点。b>pread,读取一个多项式,并将其转换成循环存储表示。返回指向该多项式的头结点的指针。c>pwrite,输出多项式,采用能够清楚显示的形式。d>padd,计算d=a+b。不改变a 和b。e>psub, 计算 d=a-b。不改变a 和b。f>pmult,计算d=a*b。不改变a 和 b。g>eval,计算多项式在某点a 的值,其中a 是一个浮点型常量。返回结果为浮点数。h>perase, 把存储表示为循环链表的多项式返还给可用空间表。实现提示为了进一步简化加法算法,把多项式的头结点的指数域设为-1。*6. 稀疏矩阵的完全链表表示与其运算问题描述稀疏矩阵的每个结点包含down,right,row,col 和 value 五个域。用单独一个结点表示一个非零项,并将所有结点连接在一起,形成两个循环链表。使得第一个表即行表,把所有结点按照行序同一行按列序用right 域起来。使得第二个表即列表,把所有结点按照列序同一列按行序用 down 起来。这两个表共用一个头结点。另外,增加一个包含矩阵维数的结点。稀疏矩阵的这种存储表示称为完全链表表式。实现一个完全链表系统进行稀疏矩阵运算,并分析下列操作函数的计算时间和额外存储空间的开销。2设计目的认识和掌握稀疏矩阵的完全链表表示;能够建立并运用这种存储结构<3>基本要求建立一个用户友好、菜单式系统进行下列操作,并使用合当的测试数据测试该系统。读取一个稀疏矩阵建立其完全链表表示输出一个稀疏矩阵的容删除一个稀疏矩阵两个稀疏矩阵相加两个稀疏矩阵相减两个稀疏矩阵相乘稀疏矩阵的转置4实现提示链表上的操作。*7. 实现简单数字图像处理问题描述一幅图像就是一个从位置集到颜色集的变换。考虑二维图像,位置集实际上就是一个矩阵, 此时一幅图像实际上就是一个容为颜色矩阵。如果颜色为0-255 间的整数,表示该位置的灰度等级,0 为黑色,255 为白色,此时的图像称为灰度图。而图像的处理就是在该矩阵进行相关计算。一种常见的计算就是通过一点和周围8 个点的信息共同决定该点的新值:如一点的新值为该点和周围8 点颜色值之和的均值,这一操作可用下图表示。显然这样处理后,图像会变得平滑,因此称为平滑操作。显然将上述操作变为下图时,就成为锐化操作。要现若干基本的图像处理操作。基本要求 熟悉 Windows 下 BMP 文件的格式,能够实现其读写<只考虑灰度图像>。实现图像的平滑和锐化操作,其它处理操作选做。 需用VC+作为语言。*8. 回文判断问题描述试写一个算法,判断依次读入的一个以为结束符的字母序列,是否为形如序列 1&序列 2模式的字符序列。其中序列 1 和序列 2 中都不含字符&,且序列 2 是序列 1 的逆序列。例如, a+b&b+a是属该模式的字符序列,而+&则不是。*9. 商品货架管理问题描述商品货架可以看成一个栈,栈顶商品的生产日期最早,栈底商品的生产日期最近。上货时,需要倒货架,以保证生产日期较近的商品在较下的位置。基本要求针对一种特定商品,实现上述管理过程。实现提示用栈模拟货架和周转空间。测试数据由学生依据软件工程的测试技术自己确定。注意测试边界数据,如空栈。*10. 停车场管理问题描述设停车场只有一个可停放n 辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场按车辆到达时间的先后顺序,依次由北向南排列大门在最南端,最先到达的第一辆车停放在车场的最北端,若车场已停满 n 辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场某辆车要离开时,在它之后开入的车辆必须先退出车场为它让路,待该辆车开出大门外,其它车辆再按原次序进入车场,每辆停放在车场的车在它离开停车场时必须按它停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。测试数据设 n=2,输入数据为:A,1,5,A,2,10,D,1,15,A,3,20,A,4,25,A,5,30,D,2,35,D,4,40,E,0,0。每一组输入数据包括三个数据项:汽车"到达"或"离去"信息、汽车牌照与到达或离去的时刻,其中,A表示到达;D表示离去,E表示输入结束。基本要求以栈模拟停车场,以队列模拟车场外的便道,按照从终端读入的输入数据序列进行模拟管理。每一组输入数据包括三个数据项:汽车"到达"或"离去"信息、汽车牌照与到达或离去的时刻, 对每一组输入数据进行操作后的输出数据为:若是车辆到达,则输出汽车在停车场或便道上的停车位置;若是车离去;则输出汽车在停车场停留的时间和应交纳的费用在便道上停留的时间不收费。栈以顺序结构实现,队列以链表实现。实现提示需另设一个栈,临时停放为给要离去的汽车让路而从停车场退出来的汽车,也用顺序存储结构实现。输入数据按到达或离去的时刻有序。栈中每个元素表示一辆汽车,包含两个数据项: 汽车的牌照和进入停车场的时刻。*11. 电梯运行仿真程序问题描述办公大楼有若干层例如,十层,每层有电梯,同时有步行楼梯;全楼有若干部例如,不多于 10 部电梯同时供使用,电梯容量为 24 人,速度每上下一层需5 秒,在某一层停下至少 15 秒。其运行状态可分:向上、向下、停止,当前乘客数,当前所在层数。它设有一个"按钮数组",例如第五层的按钮按下,意味着有乘客在第 5 层到达目标层, 等等。在楼的每一层,有电梯数,有按钮表示有人等待向上或向下,由若干人在等待,有若干电梯在本层停下,等等。在大楼中包括进出的总人数不超过 500 人,每个人站在电梯前有个目标层,他有一个最大的忍受等待时间,因为他可以选择电梯或是步行走楼梯,等等。还有下面若干假设:在每个时间段要进大楼的人数在0199 之间随机取值;用电梯的每个人的目标层在 110 之间取值;一个人在进电梯或改走楼梯之前的等待时间在180360 秒围随机发生;一个人到达目标层后第二次再乘电梯中间的工作时间在4006600 秒间随机取值。基本要求编写一个程序,模拟办公大楼中全部电梯的工作过程。这个仿真程序可以用来监测系统运行情况,改善大楼管理,它也可以看成是一种游戏程序。屏幕显示的布局设计12. 二叉树与其遍历问题描述建立一棵二叉树,并对其进行遍历先序、中序、后序,打印输出遍历结果。基本要求从键盘接受输入先序,以二叉链表作为存储结构,建立二叉树以先序来建立,并采用递归算法对其进行遍历先序、中序、后序,将遍历结果打印输出。测试数据ABCDEGF其中表示空格字符则输出结果为:先序:ABCDEGF 中序:CBEGDFA 后序:CGBFDBA 选作容采用非递归算法实现二叉树遍历。2、打印二叉树结构问题描述按凹入表形式横向打印二叉树结构,即二叉树的根在屏幕的最左边,二叉树的左子树在屏幕的下边,二叉树的右子树在屏幕的上边。测试数据由学生依据软件工程的测试技术自己确定。注意测试边界数据,如空二叉树。3、打印树结构问题描述按凹入表形式打印树形结构。测试数据由学生依据软件工程的测试技术自己确定。注意测试边界数据,如空树。实现提示1利用树的先根遍历方法;2利用结点的深度控制横向位置。*13. 图遍历的演示问题描述很多涉与图上操作的算法都是以图的遍历操作为基础的。试写一个程序,演示无向图的遍历操作。基本要求以邻接表为存储结构,实现连通无向图的深度优先和广度优先遍历。以用户指定的结点为起点,分别输出每种遍历下的结点访问序列和相应生成树的边集。测试数据由学生依据软件工程的测试技术自己确定。注意测试边界数据,如单个结点。实现提示 设图的结点不超过 30 个,每个结点用一个编号表示如果一个图有n 个结点,则它们的编号分别为 1,2,n。通过输入图的全部边输入一个图,每个边为一个数对,可以对边的输入顺序作出某种限制。注意,生成树的边是有向边,端点顺序不能颠倒。*14. 学生选课系统问题描述大学里实行学分制。每门课都有一定的学分。每个学生均需要修满规定数量的课程才能毕业。其中有些课程可以直接修读,有些课程需要一定的基础知识,必须在选了其他一些课程的基础上才能修读。例如,数据结构必须在选修了程序设计基础之后才能选修。我们称程序设计基础是数据结构的"先修课"。假定每门课的直接先修课至多只有一门,两门课可能存在相同的先修课。例如:课程号先修课号学分101211323403524上例中,1 是 2 的先修课,即如果要选修 2,则 1 必定被选。基本要求学生不可能学完大学里开设的所有课程,因此每个学生必须在入学时选定自己要学的课程。每个学生所修的学分数的下限是给定的。现在编写一个"学生选课系统",任意给定一种课程体系总课程数,课程之间的修读先后制约关系,学生毕业要求修的课程学分数,该系统能帮助学生找出一种选课方案,使得他所选课程数目最少,并获得毕业所需学分,并且必须满足先修课程优先的原则。具体功能如下:1. 将课程体系存放为课程体系文件CourseHierarchy.txt;2. 将课程体系文件CourseHierarchy.txt 转换左孩子右兄弟二叉树表示;3.在此基础上对二叉树进行先序、中序、后序遍历。4.给出选课方案。*15. 设计一个哈夫曼码的编/译码系统基本要求该系统应具有以下功能:1I:初始化Initialization。从终端读入字符集大小 n,以与n 个字符和n 个权值,建立哈夫曼树,并将它存于文件hfmTree 中。2E:编码Encoding。利用已建好的哈夫曼树如不在存,则从文件 hfmTree 中读入,对文件ToBeTran 中的正文进行编码,然后将结果存入文件CodeFile 中。3D:译码Decoding。利用已建好的哈夫曼树将文件 CodeFile 中的代码进行译码,结果存入文件TextFile 中。4P:打印代码文件Print。将文件 CodeFile 以紧凑格式显示在终端上,每行 50 个代码。同时将此字符形式的编码文件写入文件CodePrin 中。5T:打印哈夫曼树Treeprinting。将已在中的哈夫曼树以直观的方式树或凹入表形式显示在终端上,同时将此字符形式的哈夫曼树写入文件TreePrint 中。实现提示1编码结果以文本方式存储在文件CodeFile 中。2用户界面可以设计为"菜单"方式:显示上述功能符号,再加上"Q",表示退出运行 Quit。请用户键入一个选择功能符。此功能执行完毕后再显示此菜单,直至某次用户选择了"Q"为止。3在程序的一次执行过程中,第一次执行I,D 或C 命令之后,哈夫曼树已经在存了,不必再读入。每次执行中不一定执行I 命令,因为文件hfmTree 可能早已建好。测试数据1利用下面这道题中的数据调试程序。某 系 统 在 通 信 联 络 中 只 可 能 出 现 八 种 字 符 , 其 概 率 分 别 为0.25,0.29,0.07,0.08,0.14,0.23,0.03,0.11,试设计哈夫曼编码。2用下表给出的字符集和频度的实际统计数据建立哈夫曼树,并实现以下报文的编码和译码:"THISPROGRAMISMYFAVORITE"。16. 校园导游咨询系统问题描述设计一个校园导游程序,为来访的客人提供信息查询服务。基本要求1设计学校的校园平面图,所含景点不少于 10 个,以图中顶点表示校各景点,存放景点名称、代号、简介等信息,以边表示路径,存放路径长度等相关信息。2为来访客人提供图中任意景点相关信息的查询;3为来访客人提供从校门口到图中任意景点的问路查询;*17. 推销员问题:问题描述有一个推销员要到NN>0个城市去推销产品,他从某个城市出发,经历每个城市,且每个城市只能去一次,然后回到初始城市,以距离作为代价,他希望找出一个最佳路径。这 N 个城市相互都有道路可通,但距离各不相同,城市个数和各个城市的相通距离可由学生自己设定。基本要求1可以输入城市个数不少于10 个、输入城市信息和城市之间的距离为整数;2按照输入出发城市,根据城市的距离最短给出路径选择。3界面要求:有合理的提示和人机交互。*18. 全国交通咨询模拟问题描述处于不同目的的旅客对交通工具有不同的要求。例如,因公出差的旅客希望在旅途中的时间尽可能的短,出门旅游的游客则期望旅费尽可能省,而老年旅客则要求中转次数最少。编制一个全国城市间的交通咨询程序,为旅客提供最优决策的交通咨询。基本要求1提供对城市信息进行编辑如:添加或删除的功能;2城市之间有两种交通工具:火车或飞机,提供对全国城市交通图和列车时刻表与飞机航班表进行编辑的功能。信息的输入方式可以是文件输入和键盘输入两种方式3提供两种最优决策:最快到达和最省钱到达。选作:旅途中转次数最少的最优决策4旅途中耗费的总时间应该包括中转站的等候时间。5咨询以用户和计算机的对话方式进行。a由用户输入起始站、终点站、最优决策原则和交通工具;b输出信息:最快需要多长时间才能到达或者最少需要多少旅费才能到达,并详细说明依次于何时乘坐哪一趟列车或哪一次班机到何地。19. 关键路径问题问题描述设计一个程序求出完成整项工程至少需要多少时间以与整项工程中的关键活动。基本要求1对一个描述工程的AOE 网,应判断其是否能够顺利进行。2若该工程能顺利进行,输出完成整项工程至少需要多少时间,以与每一个关键活动所依附的两个顶点、最早发生时间、最迟发生时间。*20. 二叉排序树问题描述从键盘读入一组数据,建立二叉排序树并对其进行查找、遍历、格式化打印等有关操作。基本要求建立二叉排序树并对其进行查找,包括成功和不成功两种情况,并给出查找长度。测试数据由学生依据软件工程的测试技术自己确定。注意测试边界数据。选作容实现二叉排序树的插入、删除操作。*21. 部排序算法比较问题描述各种部排序算法的时间复杂度分析结果只给出了算法执行时间的阶,或大概执行时间。试通过随机的数据比较各算法的关键字比较次数和关键字移动次数,以取得直观感受。基本要求1对以下 10 种常用的部排序算法进行比较:直接插入排序;折半折入排序;二路插入排序;希尔排序;起泡排序;快速排序;简单选择排序;堆排序;归并排序;基数排序。2待排序表的表长不少于 100;其中的数据要用伪随机数产生程序产生;至少要用 5 组不同的输入数据作比较;比较的指标为有关键字参加的比较次数和关键字移动次数关键字交换计为 3 次移动。测试数据由随机产生器决定。实现提示主要工作是设法在程序中适当的地方插入计数操作。程序还可以包括计算几组数据得出结果波动大小的解释。注意分块调试的方法。选作容对不同的输入表长做试验,观察检查两个指标相关于表长的变化关系。还可以对稳定性做验证。22. 统计成绩问题描述给出 n 个学生的 m 门考试的成绩表,每个学生的信息由学号、以与各科成绩组成。对学生的考试成绩进行有关统计,并打印统计表。基本要求1按总数高低次序,打印出名次表,分数相同的为同一名次;2按名次打印出每个学生的学号、总分以与各科成绩。测试数据由学生依据软件工程的测试技术自己确定。注意测试边界数据。选作容对各科成绩设置不同的权值。*23. 运动会计分系统问题描述假设参加运动会有 n 个系,系编号为 1n。比赛分成 m 个男子项目,和 w 个女子项目。项目编号为男子 1m,女子m+1m+w。不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为:5、3、2;哪些取前五名或前三名由学生自己设定。m<=10,n<=15基本要求系统功能要求:1可以输入各个项目的前三名或前五名的成绩;2能统计各系总分;3可以按系编号、系总分、男女团体总分排序输出;4可以按系编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名的系。实现提示1输入数据形式和围:系或运行项目可以用 20 以的整数表示;也可以直接输入系的名称或运动项目的名称;2界面要求:有合理的提示,每个功能可以设立菜单,根据提示,可以完成相关的功能要求。3存储结构:学生自己根据系统功能要求自己设计,但是要求运动会的相关数据要存储在数据文件中,并在上交资料中说明所用到的存储结构;4测试数据:测试数据与测试结果请在上交的资料中写明。*24. 比较常用排序算法基本要求直接插入排序、希尔排序、直接选择排序、堆排序、起泡排序、快速排序。1随机生成一组待排序数据,个数不少于 100 个;2比较各种排序算法对同一组数据排序所需要的关键字比较次数和关键字移动次数,至少使用 5 组数据进行比较;3对比较结果进行简单分析。*25. 学生成绩管理系统问题描述:该系统实现对若干个大学生的学习成绩进行管理。至少包括以下信息: 学号、科目、成绩,学期。学期取值围可为 1-8。功能要求:1. 使用中文菜单,界面设计和用户输入输出要人性化些;2. 将学生信息保存在文本文档中,具体对学生信息进行插入删除查询操作时,将保存在文本文档中的学生信息提取出来 ,保存在自己定义的数据结构中,然后再对该数据结构进行操作,所有操作完成,或者在相应的命令后,再将学生信息保存到文本文档中。3. 具有数据输入功能,输入的数据能最终保存在文件中;4. 具有数据删除功能,能最终从文件中删除;5. 排序功能,根据自己设计的数据结构,设计排序算法6. 具有多种查询如按学号查询、按查询、按成绩查询等与输出功能;7. 其它功能如各种统计,统计每个学生所有课程的平均分,统计某门课程所有学生的平均分等等8. 学生信息的修改比如修改学生,修改学生某门课程的成绩说明:1功能各方面越完善越好2自定义的数据结构可以使用数组,链表,树等,可以使用多种数据结构来存放数据,然后在其上使用不同的排序算法。3若用数组,必须动态分配空间文本文件中最好有一行表示学生人数算法要点:把问题看成是对线性表的操作。将学生成绩组织成顺序表,则登记学生成绩即是建立顺序表操作;查询学生成绩、插入学生成绩、删除学生成绩即是在顺序表中进行查找、插入和删除操作。*26. 简易客房管理系统问题描述:该系统能简单实现对客栈的住宿情况进行管理。至少包括以下信息: 房号、房型、单价每床、已住人数;住客、性别、年龄、身份、,房号,床号,入住日期、入住时间、离店日期、离店时间。这些信息应存放在两个文件中,分别是客房信息文件、住客信息文件。"房型"可取值 1-3,分别表示单人间、双人间、通铺可以住很多人的房间功能要求:1. 具有建立数据文件<客房信息文件、住客信息文件>功能;2. 具有数据输入功能;3. 具有数据修改功能;4. 具有数据删除功能;5. 能查询查找一些基本信息如按房号查询、按查询、空余客房查询等;6. 具有多种统计功能要求有一定的实用性如某客房当前有那些空床、某住客应付多少费用、某天住店总人数和总收入等 7能具有排序功能比如在查询所有的客房信息时,能根据房间价格进行排序,方便客人挑选房间等等说明:1功能各方面越完善越好2自定义的数据结构可以使用数组,链表,树等,可以使用多种数据结构来存放数据,然后在其上使用不同的排序算法。3若用数组,必须动态分配空间文本文件中最好有一行来表示数组应该有多大,这样便于动态分配空间*27. 人事档案管理系统问题描述:该系统能简单实现对人事档案的管理。该系统包括: 人员基本情况管理、工资管理和考勤管理等几个方面的功能。用户通过输入工资、考勤、职工履历等基本信息,由系统自行生成相应的统计数据以供用户查询, 能对这些基本信息进行更新和删除。至少包括以下信息:人员履历表:员工编号,员工,性别,年龄,部门,职位,受教育年限职工工资表:员工编号,基本工资,缺勤扣发工资,扣税,实发工资月考勤登记表:员工编号,月缺勤天数注:假设每个员工每天缺勤扣发工资的多少跟其基本工资存在一定关系,比如是该基本工资的 20 分之一;假设扣税金额基本工资缺勤扣发工资2000×10,而若基本工资 缺勤扣发工资2000 的值小于 2000 则扣税金额为 0功能要求:1. 具有建立数据文件<人员履历表文件、职工工资表文件、月考勤登记表>功能;2. 具有数据输入功能;3. 具有数据修改功能;4. 具有数据删除功能;5. 能查询查找一些基本信息如按员工编号查询、按员工和部门组合查询等,如生成各部门员工花名册;6. 具有多种统计功能要求有一定的实用性如不同部门的员工平均工资比较除了用数字表示外,也可以用星号画图的方式来直观的表示;不同性别员工工资比较;某部门部,不同职位员工工资比较;不同受教育水平人的平均工资比较;部门最高实发工资等等7. 具有排序功能比如将各部门职工工资平均值进行排序,将部门部职工工资进行排序等等各个功能模块简要叙述具体实现时,并不局限于这些功能,越完善越好² 人员基本情况管理:提供对"人员履历表"数据输入、组合条件查询、统计功能;² 职工工资管理:提供对"职工工资表"数据的输入、查询、按统计、显示功能,完成每月对"职工工资表"数据的月统计,以此生成"职工工资总额构成情况表"实现该表的查询、显示功能。² 职工考勤管理:提供对各部门"月考勤登记表"数据的录入、查询、统计功能;说明:1功能各方面越完善越好2自定义的数据结构可以使用数组,链表,树等,可以使用多种数据结构来存放数据,然后在其上使用不同的排序算法。3若用数组,必须动态分配空间文本文件中最好有一行来表示数组应该有多大,这样便于动态分配空间*28. 进销存货物管理系统问题描述:该系统能进行简单的货物管理,进货,销售货物,退货等管理至少包括如下信息:货物标号,货物名称,货物产地,入库价格,入库时间,现存货物数量,已经销售数量,销售平均单价注:每次销售后,都需要对现存货物数量进行更新,对已销售数量进行更新,也需要对销售平均单价进行更新功能要求:1. 具有建立数据文件<货物管理表>的功能;2. 具有数据输入功能;3. 具有数据修改功能;4. 具有数据删除功能当一些已经过时旧的商品被特价处理后,将其删除,不再进货;5. 能查询查找一些基本信息如能查询剩余件数小于某个特定值的商品,以便于与时进货;6. 具有多种统计功能要求有一定的实用性如统计每种货物是否有盈利将销售平均单价跟入库价格进行比较,所有货物的盈利或亏损等等7. 具有排序功能比如对货物盈利水平进行排序比较等等说明:1功能各方面越完善越好2自定义的数据结构可以使用数组,链表,树等,可以使用多种数据结构来存放数据,然后在其上使用不同的排序算法。3若用数组,必须动态分配空间文本文件中最好有一行来表示数组应该有多大,这样便于动态分配空间*29. 图书管理系统问题描述:该系统能进行简单的图书管理功能至少包括如下信息:图书编号,图书名称,作者,总共册数,在馆册数,现存地址,借阅次数注:现存地址是假设图书馆有多个书库,不同种类的书存放于不同的地方功能要求:1. 具有建立数据文件<图书信息>的功能;2. 具有数据输入功能;3. 具有数据修改功能借书或者还书都需要修改图书数量信息;4. 具有数据删除功能当图书因为年代久远,或者遗失,也许需要对其进行删除操作;5. 能查询查找一些基本信息这里的查询功能应该较为强大,能通过作者进行查询,书名查询,或者结合作者一起进行查询等等 6具有多种统计功能要求有一定的实用性如统计每本书的借阅次数,方便将来新近图书。统计每个书库中图书的数量等等7具有排序功能比如对每本图书的借阅次数进行排序各个功能模块简要叙述具体实现时,并不局限于这些功能,越完善越好² 新近图书:在图书信息表中添加相应信息;² 旧书处理:在图书信息表中删除相应信息;² 借书还书: 对图书信息表进行修改,若在馆册书为 0,则不允许继续借阅;² 图书信息的统计² 图书信息的排序² 图书信息的查找说明:1功能各方面越完善越好2自定义的数据结构可以使用数组,链表,树等,可以使用多种数据结构来存放数据,然后在其上使用不同的排序算法。3若用数组,必须动态分配空间文本文件中最好有一行来表示数组应该有多大,这样便于动态分配空间*30. 运动会分数统计问题描述:参加运动会有 n 个学校,学校编号为 1n.比赛分成 m 个男子项目,和 w 个女子项目.项目编号为男子1.m,女子m+1.m+w.不同的项目取前五名或前三名积分;取前五名的积分分别为:7、5、3、2、1,前三名的积分分别为: 5、3、2;哪些取前五名或前三名由同学自己设定。m<=20,n<=20功能要求:1. 可以输入各个项目的前三名或前五名的成绩;2. 能统计各学校总分;3. 可以按学校编号、学校总分、男女团体总分排序输出;4. 可以按学校编号查询学校某个项目的情况;可以按项目编号查询取得前三或前五名的学校。规定:输入数据形式和围:20 以的整数如果做得更好可以输入学校的名称,运动项目的名称输出形式:有中文提示,各学校分数为整形界面要求:有合理的提示,每个功能可以设立菜单,根据提示,可以完成相关的功能要求。存储结构:学生自己根据系统功能要求自己设计,但是要求运动会的相关数据要存储在数据文件中*31. 民航订票系统任务:通过此系统可以实现如下功能: 1录入可