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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

学生成绩管理系统.docx

1、学生成绩管理系统综合程序课程设计说明书课程设计名称:综合程序课程设计课程设计题目:学生成绩管理系统学院名称:信息工程学院专业:电子信息工程班级:学号:评分:教师:2017年3月3日由每位学生填写、由任教教师保存待查摘要该学生成绩管理系统能够对学生信息进行保存、查询、修改、排序等基本功能,对学生成绩进行了有效且便利的管理。本次是利用计算机中的VC6.0绿色版软件来完成,利用了不同功能模块程序实现所需功能。成绩管理系统让老师和同学甚至家长们更加直观方便的了解到学生们的成绩,给生活带来不少便利,也增加了自身的实践动手能力。关键词:增加删除、修改排序、查询保存、管理系统、成绩查询。一、设计要求 41.

2、基本要求 42. 提高要求 4二、实验内容 4三、设计的原理 6四、系统组成 7五、概要设计 81.信息维护 82.信息查询 83.信息排序: 94、大概程序程序流程图 9六、 详细设计 10七、调试结果与分析 121、调试方法与技巧 122、调试结果 12结论 16参考文献 16附录 17一、设计要求1.基本要求能够准确实现学生成绩管理系统的基本维护、统计、排序已经查询的功能。并且学生信息能以文件的形式进行保存、读取和管理。2.提高要求尽量增加新的功能模块,使得系统功能更加多样化,在程序中注意格式,排版整齐,记得标上注释,利于理解。二、实验内容学生成绩管理系统现有学生成绩信息,内容如下姓名学

3、号语文数学英语政治张明明01 67 78 82 90李成友02 78 91 88 80张辉灿03 68 82 56 87王露04 56 45 77 67陈东明05 67 38 47 70.请用C编写一系统,实现学生信息管理,软件的入口界面应包括如下几个方面:(一)功能要求:(1)信息维护:要求:学生信息数据要以文件的形式保存,能实现学生信息数据的维护。此模块包括子模块有:增加学生信息、删除学生信息、修改学生信息(2)信息查询:要求:查询时可实现按姓名查询、按学号查询(3)成绩统计:要求:A输入任意的一个课程名(如数学)和一个分数段(如60-70),统计出在此分数段的学生情况。(4)排序:能对用

4、户指定的任意课程名,按成绩升序或降序排列学生数据并显示排序结果(使用表格的形式显示排序后的输出结果)(使用多种方法排序者,加分)(二)其它要求:(1)使用C或C+语言,源程序要有适当的注释,使程序容易阅读(2)采用文本菜单界面(3)学生可增加新功能模块三、设计的原理用数组或链表数据结构完成一个学生成绩管理系统,此系统的具体功能要求如下:(1)信息维护功能1、增加学生信息:输入学生学号、性别、语文、数学、英语、政治四门课成绩,可插入一个或多个学生信息到当前编辑的班级数据中。2、删除学生信息:可按学号或者姓名删除一个或多个学生信息。3、修改学生信息:可按学号或者姓名修改学生语文、数学、英语、政治四

5、门课任一门及多门科目成绩。4、学生信息每一班存为一个数据文件,数据文件可在程序中编辑和重新保存。5、用户输入学生信息可随时保存数据文件。(2)信息查询功能1、按某一学科分数段查询2、按学号查询学生信息;3、按姓名查询学生信息;(3)排序功能1、按学号输出一个班学生信息:学号、语文、数学、英语、政治成绩和总成绩到屏幕和文件。2、成绩排名按总成绩或各科成绩排序输出学生信息四、系统组成系统以如下几个模块组成:(一)学生信息增加及修改、删除模块增加学生的信息:学号、语文、数学、英语、政治四门成绩。当然也可以进行修改和删除。(二)文件保存功能模块可以将学生信息存为一个数据文件。用户输入的学生信息可随时保

6、存数据文件。(三)查询功能模块在此模块里,用户可实现以下操作:1、按某科目分数段查询学生信息;2、按学号查询学生信息;3、按姓名查询学生信息;(四)文件读取功能模块在此模块中,用户可以装入文件中所有学生的信息。(程序中为data.txt文件)(5)排序模块在此模块中,可以通过学号或者各类科目成绩或总分进行排序。程序开头与结尾需要定义两个类和一主函数,使得程序具备完整性。五、概要设计系统功能可分为三大类:信息维护、信息查询已经信息排序。如下三个系统层次结构图如图所示:1.信息维护图1.1信息维护功能概要图2.信息查询图1.2信息维护功能概要图3.信息排序:图1.3信息排序功能概要图了解大概功能,

7、可以根据这些来确定系统具体分支,可用17分别代表添加、删除、修改、查询、排序、保存、读取。4、大概程序程序流程图6、详细设计1、准备工作:首先,导入std命名空间中所有名称,设max为100再准备头文件:#include,#include,#include,#include,#include然后,定义两个类student和cla,分别定义了程序中主要使用的成员;建立构造函数和解析函数及声明各类函数。2、构造sadd()添加函数先定义所需的q,name,num,x,y,z,m。用DOS下的清屏命令,再输出给用户的提示语句,用“q=new student(name1,num1,x1,y1,z1,m

8、1);”建立新的student。利用链表判断输入的学号是否与头结点或后面的结点数据相同,若不同则用“stu=q;”增加学生信息。3、构造sremove()删除函数准备工作如上(2)一样,用while()函数找出要删除的学生信息对应结点,若找到则删除,在删除之前要确定是否删除:“cout确定删除吗?Y/Nendl;”这里用if语句判断用户回答是“Y”还是“N”。删除时也要分是删除第一个结点还是后续结点。补缺后用delete删除p1。4、构造samend()修改函数大体和3一样,修改前的准备,确定要修改的结点,最后用cin直接修改。5、构造ssearch()查询函数查询函数有多个分支,这里都用选择

9、语句case来对不同的情况进行编程。在这里只需逻辑清晰,语法没有错误就能完成,但也要注意括号的搭配和break的使用。在用for语句时要注意循环次数不能过大,应对应学生的人数。6、构造staxis()排序函数用case语句使输入的17数字分别对应函数pxh()(学号排序)、psx()(数学)、pyw()(语文)、pyy()(英语)、pAA()(总分)、返回、pzz()(政治)。这些排序函数定义内容几乎一样。首先用for语句判断n(信息条数)为多少,如果头结点大于第二个的头结点则交换,再判断中间的结点大小则交换,最后依次重复。7、构造ssave()函数sload()函数(保存与读取)在这里注意链

10、表要求即可。8、定义主函数产生操作界面也用case语句使18代表不同功能。(详见附录)七、调试结果与分析1、调试方法与技巧代码完成后,保存代码并尝试运行程序,启动调试。往往会出现以下几种常见错误。1case语句中内容重复,没有用一函数替代,使程序过为繁琐。2括号没有匹配;3循环体的逻辑错误;4 case语句中缺少了break,没有跳出循环。5错误使用了for语句,造成已经出现结果后(链表为空)依旧继续运行,造成问题,无法继续使用该系统。2、调试结果1、学生信息的添加、删除、修改。 图2.1.1删除 图2.1.2添加学生信息图2.1.3修改学生信息图2.1.4此时文件的内容2、按姓名查询。 图2

11、.2.13.按学号查询。 图2.3.14、按成绩查询。图2.4.15、成绩排序。 图2.5.1学号排序 图2.5.2单科(数学)成绩排序 图2.5.3总分排序6、保存: 图2.6.17、读取: 图2.7.18、退出:图2.8.1结论虽然过程有些磕磕绊绊,但最后成绩管理系统终于成功了。该系统能够为大家带来极大的便利,便于以后成绩的有效管理。以后大家像成绩排序,找出某个科目及格的学生也容易很多。该系统虽具有基本的功能,但还是存在一些不足。例如增加删除学生信息时不能在界面上自动呈现增加或者删除的结果,需要操作者手动打开文件或者通过排序来间接查看结果。这次课设让大家学到了很多书本外的知识,锻炼了实践操

12、作的能力。不仅熟悉了VC6软件,也让大家知道,纸上谈兵远远没有自己动手体验来的深刻。参考文献1.黄维通,贾续涵、Visual C+面对对象与可视化程序设计(第三版)、清华大学出版社、2011年06月版2.谭浩强、C语言程序设计(第四版)、清华大学出版社、2010年06月版附录#include#include#include#include#include/用于程序的暂停属于c的运用方法using namespace std;/导入std命名空间中所有名称。#define max 100;/设max为100class student/定义类student定义了程序中主要使用的成员 public:

13、student*next;/定义next指针 public:string name;/ long num;/学号 int x,y,z,m;int low,high;/数学,语文,英语,政治 int AA;/总分 void play() coutname学生的学号是num,数学:x,语文:y,英语:z,政治:m,总分:AAnext; delete stu; stu=p; stu=0; /这一部分是对函数的声明 void sadd();/添加 void sremove();/删除 void samend();/修改 void ssearch();/查询 void staxis();/排序 void

14、 ssave();/保存 void sload();/读取 /排序函数的声明 void pxh(); void psx(); void pyw(); void pyy(); void pzz(); void pAA();/共有5个排序函数 private:student*stu;/头接点;void cla:sadd()/此处构造了添加学生函数 student*q; string name1; long num1; int x1,y1,z1,m1; system(cls);/调用DOS下的的清屏命令“cls” coutn*增加的学生*nendl; cout请输入学生的(中间用空格间隔)endl;

15、 cout姓名学号数学成绩语文成绩英语政治成绩:name1num1x1y1z1m1; q=new student(name1,num1,x1,y1,z1,m1); q-next=0; q-AA=x1+y1+z1+m1; if(stu) student*t; t=stu; if(t-num=num1) cout学号已存在,请重新输入next) if(t-num=num1) cout学号已存在,请重新输入next; t-next=q; else stu=q; cout输入完毕endl;void cla:sremove()/删除 system(cls); int num1; coutn*删除学生信息

16、*n; coutnum1;/查找要删除的结点 student*p1,*p2; p1=stu; while(p1) if(p1-num=num1) break; else p2=p1; p1=p1-next; /删除结点if(p1!=NULL)/若找到结点,则删除 p1-play(); cout确定删除吗?Y/Nc; if(toupper(c)!=Y) return; if(p1=stu)/若要删除的结点是第一个结点 stu=p1-next;/将第二个结点往上推,成为头结点。 delete p1; else/若要删除的结点是后续结点 p2-next=p1-next;/补缺 delete p1;

17、cout找到学号为num1的学生,并删除n; else/未找到结点 cout未找到想要删除的学生!n; void cla:samend()/修改 system(cls);long num1;coutn*修改学生信息*n;coutnum1;/查找要修改的结点 student*p1,*p2;p1=stu; while(p1) if(p1-num=num1) break; else p2=p1;p1=p1-next; if(p1!=NULL) cout学号是num1的学生的信息endl; coutname数学x语文y英语z政治mendl; cout请输入修改后的信息:姓名数学成绩语文成绩英语政治成绩

18、p1-namep1-xp1-yp1-zp1-m; p1-AA=p1-x+p1-y+p1-z+p1-m;/求总分 cout修改成功endl;else/未找到接点cout未找到!endl;void cla:ssearch()/查询 system(cls); coutn*查询学生信息*nendl; cout请输入查询方式:endl; cout1.按学号查询endl; cout2.按姓名查询endl; cout0.按科目分数段查询endl; cout3.返回c; switch(c)/通过switch语句来选择排序函数 case0: int x,y,z,m; long num; char w; int

19、high,low; cout输入要查找成绩科目代表的数字(数语英政分别为ad):ww;/查找要查询的结点 cout最低分为:low; cout最高分为:high; student*p1,*p2; p1=stu; switch(w) casea: cout数学成绩在low-high分数段的学生为:x=low&p1-x=high) cout:name数学:x语文:y英语:z政治:mnext; cout查询完毕n; break; caseb: cout语文成绩在low-high分数段的学生为:y=low&p1-y=high) cout:name数学:x语文:y英语:z政治:mnext; cout查询

20、完毕n; break; casec: cout英语成绩在low-high分数段的学生为:z=low&p1-z=high) cout:name数学:x语文:y英语:z政治:mnext; cout查询完毕n; break; cased: cout政治成绩在low-high分数段的学生为:m=low&p1-m=high) cout:name数学:x语文:y英语:z政治:mnext; cout查询完毕n; break; break; case1: long num1; cout要查询的学号num1;/查找要查询的结点 student*p1,*p2; p1=stu; while(p1) if(p1-nu

21、m=num1) break; else p2=p1;p1=p1-next; if(p1!=NULL) cout学号是num1的学生的信息endl; cout:name数学:x语文:y英语:z政治:mendl; cout查询完毕.; else/未找到接点cout未找到!n;/break; break; case2: string name1; cout要查询的学生姓名name1;/查找要查询的结点 student*p1,*p2; p1=stu; while(p1) if(p1-name=name1) break; else p2=p1; p1=p1-next; if(p1!=NULL) cout

22、name1的学生的信息endl; cout学号:num数学:x语文:y英语:z政治mendl; cout查询完毕.; else/未找到接点 coutnext)/p1-next!=0 n+;p1=p1-next; cout共有n条信息.endl; int i; p1=stu; for(i=1;inump1-next-num)/如果头结点大于第二个的 p2=p1-next; p1-next=p1-next-next; p2-next=p1;/头结点交换 stu=p2;/下一个学生 p1=stu;/交换 while(p1-next-next)/中间的交换 p2=p1;p1=p1-next; if(p1-nump1-next-num) p2-next=p1-next; p1-next=p1-next-next; p2-next-next=p1; p1=p2-next;/交换 p1=stu;do p1-play(); p1=p1-ne

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

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