ImageVerifierCode 换一换
格式:DOCX , 页数:21 ,大小:150.23KB ,
资源ID:17611139      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/17611139.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(单链表的学生成绩管理系统设计与实现Word文档下载推荐.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

单链表的学生成绩管理系统设计与实现Word文档下载推荐.docx

1、(2) 查询:查询满足条件的学生;(3) 修改:对成绩信息的数据项进行修改;(4) 删除:将满足条件的学生信息删除;(5) 输出:将全部的学生成绩信息输出。为了方便数据的读取与储存,我们采纳外部文件来进行数据储存能实现学生信息数据的爱护。1.2设计目的学生成绩治理是一个学校不可缺少的部分,它的内容关于学校的治理者和学生以及学生家长来说都至关重要,因此一个良好的学生成绩治理系统应该能够为用户提供充足的信息和快捷的查询手段。学生成绩治理系统对学校加强学生成绩治理有着极其重要的作用.由于各个大学都在连续扩招,学生的数量日益庞大,关于如何治理如此庞大的学生成绩数据显得更为复杂,传统的手工成绩治理不仅工

2、作量大,而且容易显现问题,如:效率低、保密性差,另外时刻一长,将产生大量的文件和数据,这关于查找、更新和爱护都带来了许多的困难。已不能适应时代的进展。随着科学技术的不断提高,运算机科学日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。作为运算机应用的一部分,使用运算机对学生成绩信息进行治理,具有手工治理所无法比拟的优点。例:检索迅速、查找方便、可靠性高、储备量大、保密性好、寿命长、成本低等。这些优点能够极大地提高治理者治理的效率,也是学校走向科学化、正规化治理,与世界接轨的重要条件。因此,开发设计如此一套学生成绩治理软件成为专门有必要的情况。该学生成绩

3、治理系统采纳C+语言开发研制,针对学生成绩及其数据特点,能够全面实现对学生成绩的插入、查询、修改、删除和输出等功能的运算机治理。它能使学生成绩数据的工作人员从繁重的工作中解脱出来,大大减轻了工作量,减少人为的工作失误,全面提高学生成绩治理的效率,从而使学校关于学生成绩的治理水平和技术水平跃上一个新的台阶。1.3设计目标此建立学生成绩信息治理系统,采纳运算机对学生成绩信息进行治理,进一步提高学校现代化水平。关心宽敞成绩信息治理者提高工作效率、减少工作时刻,实现学生及其家长信息查询工作流程的系统化、公平化、规范化和自动化,也为宽敞在教师提供便利快捷的成绩录入功能。为了保证系统能够长期、安全、稳固、

4、可靠、高效的运行,本课题将达到以下几个目的:(1)系统处理的准确性系统处理的准确性和及时性是系统的必要性能。在系统设计和开发过程中,要充分考虑系统当前和今后可能承担的工作量,使系统的处理能力和响应时刻能够满足高校对信息处理的需求。(2)系统处理的及时性由于学生专门关怀自己的信息正确与否以便及时同意来自学校的学习成绩信息,学生成绩信息治理功能关于整个系统的功能和性能完成举足轻重。在系统开发过程中,必须采纳一定的方法保证系统的准确性。(3)系统的保密性学生成绩信息是属于个人的隐私,因此系统在开发时,应该充分考虑系统的保密性,以保证学生的隐私权。(4)系统的开放性和可扩充性学生成绩信息治理系统在开发

5、过程中,应该充分考虑以后的可扩充性。例如学生成绩信息治理的方式的改变,学生成绩信息的需求也会不断的更新和完善。第2章 系统需求与功能分析2.1系统需求分析1) 能完成学生成绩的插入、查询、修改、删除、输出等功能;(2)采纳单链表储备结构实现;(3) 所有数据以外部文件方式储存。2.2系统功能分析(1)要设计一个学生成绩治理系统,其功能包括:插入函数Add():将学生成绩信息插入到链表中;查询函数Search():分别能够按学号和按姓名进行学生成绩查询;删除函数Delete():当需要删除的学号和姓名一致时则删除对应的学生记录;修改函数Modify():修改指定的学生成绩信息;输出函数Show(

6、):输出全部学生成绩信息;菜单函数Menu():为程序的菜单函数为实现各种功能提供便利;读取数据函数Read():从外部文件读取学生成绩信息;储存数据函数Save():将数据储存到外部文件中。(2)线性表的链接储备结构称为单链表,单链表使用一组任意的储备单元存放线性表的元素,这组储备单元能够连续也能够不连续,甚至能够零散分布在内存中的任意位置。为了正确表示元素之间逻辑关系,每个储备单元在储备数据元素的同时,还必须储备其后继元素所在地址信息,那个地址信息称为指针,这两部分组成了数据元素的储备映像,称为结点,结点结构如图2.1所示。图2.1单链表的结点构造 设p是一个指针变量,则p的值是一个指针。

7、设指针p指向某个结点,则该结点用*p表示,在单链表中,结点p由两个域组成:存放数据元素的部分和存放后继结点地址的指针部分,分别用p-data和p-next来标识,p-next指向结点ai+1,其指针与结点之间关系如图2.2所示。图2.2指针与结点之间关系的示意图2.3系统性能分析1硬件环境处理器:CPU主频在500MHz以上 内存:128MB以上硬盘空间:10MB。2软件环境操作系统: Windows 98/Me/NT/2000/XP(举荐使用Windows 2000/XP)。调试环境: Visual C+及以上版本。第3章 总体结构分析3.1系统的结构分析:通过对学生成绩信息治理系统的功能分

8、析,能够定义出系统的总体结构模块图,如图3.1所示。图3.1学生成绩治理系统总体结构设计3.2系统治理流程图:前面的分析中差不多定义了系统各个模块,属于静态建模的范畴。在系统运行时刻的动态模型应该由系统的流程决定。当用户运行该系统后能够来进行学生成绩信息插入治理、学生成绩信息查询治理、学生成绩信息删除治理、学生成绩信息修改治理及学生成绩信息输出等操作,具体的流程如图3.2所示。 图3.2系统流程图主模块应负责应用程序的主界面,由它调用其他模块.因此主模块应具有操作性好、界面清晰的特点,使用户能够专门方便地找到所需功能。依照功能需求的结果分析,主界面应该由学生成绩信息插入治理,学生成绩信息查询治

9、理、学生成绩信息修改治理、学生成绩信息删除治理和学生成绩信息输出治理组成,能够通过输入相应的数字进入相应的功能模块。4 系统详细设计和系统实现系统总体设计完成后,就能够依照需求对各个模块来进行实现了。在本系统中需要编码实现的要紧有学生成绩信息插入、学生成绩信息查询、学生成绩信息修改、学生成绩信息删除和学生成绩信息输出等5个模块。(1)学生成绩插入模块添加的信息包括学号(不承诺重复)、姓名(不承诺重复)、语文成绩、数学成绩和英语成绩。流程图如下图4.1所示。 图4.1插入模块流程图 本程序采纳的是尾插法,确实是每次将新申请的结点插在终端结点的后面,其执行过程如图4.2所示。图4.2尾插法建立单链

10、表操作示意图(2)学生成绩查询模块按姓名和学号查找学生成绩的流程图分别如下图4.3所示。 图4.3按姓名查找学生成绩信息流程图在单链表中,即使明白被访问结点的位置i,也不能像顺序表那样直截了当按序号访问,而只能从头指针动身,设置一个工作指针p,顺next域逐个结点往下搜索。当p指向某个结点时判定是否为第i个结点,若是则查找成功;否则,将工作指针p后移,立即p指向原先所指结点的后继结点。直到p为NULL时查找失败。单链表查找过程如图4.4所示。图4.4单链表查找过程的示意图按学号查询学生成绩信息同按姓名查找学生成绩信息,此处不再详细列出。(3)学生成绩修改模块第一要查找与要修改数据相匹配的信息,

11、若没有则返回失败。否则把相应的信息输出,然后再重新输入新的数据并储存到单链表。(4)学生成绩删除模块当选择删除功能时,第一输入要删除的同学的姓名,然后输入要删除的同学的学号,假如该同学存在同时姓名与学号匹配的上,则进行删除操作,否则返回失败。其流程图4.5如下: 图4.5删除学生信息模块流程图删除操作定义为将单链表的第i个结点删去。因为在单链表中结点ai储备地址在其前驱结点ai-1的指针域,因此必须第一找到ai-1的储备地址p,然后令p的next域指向ai 的后继结点,即把结点ai 从链上摘下来,最后开释结点ai的储备空间,如图4.6所示。 图4.6在单链表中删除结点指针的变化情形(5)学生成

12、绩输出模块从单链表表头遍历整个单链表,将所有数据输出。其部分代码如下: void Function:Show() char choose; Student *temp; system(cls); temp=Student_First-Next; if(!temp) cout文件许多据nn endl; coutchoose; while(choose!=1) coutOut(); temp=temp- cout while(f1-Next) f1=f1- do p=new Student; Printf(请输入您要添加的学生成绩信息:n请输入学生姓名: Sccanf(“%c”,&name); w

13、hile(f2) if(strcmp(f2-GetName(),name)=0) printf(该学生已存在,请确定姓名!nn Printf(请输入姓名: break; f2=f2- printf(请输入学号: Scanf(“%c”,no);请输入语文成绩: Scanf(“%d”,&score.Chinese);请输入数学成绩:score.Math);请输入英语成绩: Scanf(“%d”,&score.English); p-Set(name,no,score); f1-Next=p;Next=NULL;是否连续输入信息?(YN) n Scanf(“%c”,&choose); while(c

14、hoose=y|choose=Y Save(); Printf(1.返回主菜单n printf(/*删除模板*/ void Delete() /删除信息函数 char name20; Student *temp,*p; p=temp=Student_First- Scanf(“%c”,&输入学号:no); while(temp) if(strcmp(temp-GetName(),name)=0&temp-GetNo()=no) /判定该学生信息是否存在 printf( temp- printf(n是否删除(Y/N) if(choose= p-Next=temp- delete temp;删除成

15、功: break; p=temp; temp=temp-1.返回主菜单n2.连续删除choose!2 else if(choose= Delete();/*修改模板*/ void Modify() /修改学生信息函数 char choose,name20; temp=p=Student_First;请输入您要修改的学生姓名:GetName(),name)=0) Printf( temp-修改成功!1.返回主菜单n2.连续修改 Printf( Modify();/*查找模板*/ void Search() int flag(0); char t120; int t2; Student *temp=Student_First-输入查询方式:n1.按姓名查询n2.按学号查询n if(choose=请输入您要查询的姓名: Scanf(“%d”,&t1); while(temp) if(strcmp(t1,temp-G

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1