C++学生成绩管理系统论文_第1页
C++学生成绩管理系统论文_第2页
C++学生成绩管理系统论文_第3页
C++学生成绩管理系统论文_第4页
C++学生成绩管理系统论文_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

学生成绩管理系统 一、引言 教育行业的多元信息进行有效的管理工作也成为教育行业的重要任务之一。目前,学校工作繁杂、资料众多,传统的人工管理不仅复杂,也牵涉了很多的人力,对管理也造成了诸多不便,所以各高校已经引入了各类信息管理系统,为教务工作人员减轻了负担,提高了工作效率。本论文是关于学生成绩管理的一套系统,该系统是对学生的成绩进行修改和管理,而且方便快速,可以作为老师的辅助软件,对学生的各种成绩进行管理。 本系统作为对信息与计算科学专业学生的成绩进行管理的一个系统,旨在为信息与计算科学专业的老师提供一个在互联网上对学生成绩进行修改和管理的平台。通过本系统的应用可达到对学生的基础信息和课程成绩的录入、对输入的学生信息可以保存到一个数据文件、对当前打开的数据文件可以进行修改、对学生的各种相关信息进行查询以及可以对所有学生的相关信息以报表的形式输出。本系统应用于信息与计算科学专业学生的成绩管理。 本系统是采用C+语言编写的。学生成绩管理系统具有方便的数据查询和浏览的功能以及整个系统有严密的权限管理,增强了系统数据的安全性;增加、删除、修改数据方便快捷,减少教务人员的工作量,简单而且高效。 二、需求分析2.1 可行性分析 可行性分析的含义就是用最小的代价和尽可能少的时间来解决问题。而成绩管理系统正好实现了缩短时间、提高效率、减少财力的支出而完成任务的目的。 本系统采用C+语言实现了对数据的录入、修改、删除、查询、浏览、统计等功能的设计,从而实现了技术上的可行性。在当今的信息时代,计算机已为日常办公所用,操作系统也为人们所熟悉。购买计算机所需费用也能够被人们所接受。只要一台电脑,一台打印机,这个系统就可以实现其功能。本系统可以减少教务人员的工作量,提高工作效率,而且操作方便。它有着简单、直观、安全、适用等优点,使学校的教学管理更上一层楼。2.2 需求规定2.2.1 对功能的规定 功能构成用数组或链表数据结构完成一个学生成绩管理系统,此系统的具体功能要求如下:(1)学生信息录入功能 1)用户从键盘输入每个学生的信息:学号、姓名、性别、数学分析、英语、高等代数、C+语言程序设计、普通物理五门课成绩。 2)可插入一个或多个学生信息到当前编辑的班级数据中。 3)可删除一个或多个学生信息。(2)文件信息修改功能 1)学生信息每一班存为一个数据文件,数据文件可在程序中打开、编辑、修改和重新保存。 2)用户修改学生信息后可随时保存数据文件。 3)程序只能对当前打开的数据文件进行编辑。(3)查询功能 1)查询所有学生信息; 2)按学号查询学生信息; 3)按姓名查询学生信息; 4)查询一个班的总成绩和平均成绩; 5)查询一个班某一门课的总成绩和平均成绩; 6)查询某一门课的各分数段( 90)学生数。(4)报表输出功能 1)按学号由低到高输出一个班的学生信息:学号、姓名、性别、数学分析、英语、高等代数、C+语言程序设计、普通物理成绩和总成绩,并显示到屏幕上。 2)按总成绩由高到低输出学生学号、姓名信息。 注:以上功能以菜单形式供用户使用,并有一定的容错功能。2.2.1 系统的分层DFD图 学生成绩管理系统查询功能文件信息修改功能报表输出功能学生信息录入功能 按总成绩输出报表按学号输出报表删除学生信息插入学生信息 查询功能查询一个班的总成绩和平均成绩查询某一门课的各分数段学生数查询一个班某一门课的总成绩和平均成绩查询所有学生信息按学号查询学生信 息按姓名查询学生信息 图1 分层DFD图2.2.2 性能需求 软件应保证系统运行稳定,避免出现系统崩溃;软件必须保证有足够的数据精度,不影响正常业务;软件应尽量做到响应快速、操作简便。 三、软件总体设计3.1 系统整体框架整个学生成绩管理系统采用链表作为基本数据结构。创建一个类student用于保存学生的数据且是链表中的一个节点,类list作为保存整个链表之用。主函数通过switch语句来根据用户的需要连接各个模块,以实现用户的需要。3.2 基本模块介绍3.2.1 用户输入模块 在此模块中,用户将根据菜单提示结合自己的需求输入一个011的值,来实现一定的功能。3.2.2 学生信息录入模块 此模块可以让用户从键盘输入每个学生的信息:学号、姓名、性别、数学分析、英语、高等代数、C+语言程序设计、普通物理五门课成绩。用户可插入一个或多个学生信息到当前编辑的班级数据中。用户也可删除一个或多个学生信息。3.2.3 文件信息修改功能模块 用户可以用此模块将数据文件在程序中打开、编辑、修改和保存,程序只能对当前打开的数据文件进行编辑。用户在确定已录入的成绩无误之后,可以将学生信息以每一班为单位存为一个数据文件。用户修改学生信息后可随时保存数据文件。 3.2.4 查询功能模块 在此模块里,用户可实现以下操作:浏览所有学生信息;按学号查询学生信息;按姓名查询学生信息;查询一个班每个人的总成绩和平均成绩;查询一个班某一门课总成绩和平均成绩;进行成绩的统计分析:包括总人数、每门课的最高成绩、最低成绩、平均成绩、各个分数段的人数(100-90、89-80、79-70、69-60、60以下)、及格人数。3.2.5 报表输出功能模块在此模块中,用户可以浏览所有学生的信息;或者可以按学号由高到低输出一个班学生信息:学号、姓名、性别、数学分析、英语、高等代数、C+程序设计、普通物理成绩和总成绩,并显示在屏幕上;也可以按总成绩由高到低输出学生学号、姓名信息。 四、软件详细设计 4.1 主要功能模块的算法设计思路4.1.1 用户输入模块设计提示用户输入一个011的值,并存储在一个整型变量m中。4.1.2 学生信息录入模块设计通过应用list中的instu()函数,来新建一个链表中的节点,即一个新的学生信息,来进行成绩的录入功能。成绩修改功能,可以根据姓名或学号进行查询并修改相应的课程的成绩,使用了void search(char s10,int)和void search1(char s20,int)函数进行操作。search函数根据姓名查找,search1函数根据学号进行查找。因为学号和姓名,都是存储在字符数组中的,所以都是通过字符串的比较进行查找的。然后根据整形参数进行对应的课程成绩的修改。成绩删除功能,也是可以根据姓名或学号进行删除,查询的算法和成绩修改功能的查询方法是一样的,当找到要删除的节点时,因为节点都是在堆内存中保存的,所以可以直接删除掉,并将前一个节点的next指针指向被删掉的节点的next指针所指向的节点。4.1.3 文件信息修改功能模块先提示用户输入要打开的数据文件的名称,然后通过一个类ifstream的对象input来进行文件操作。首先判断文件是否存在,如果不存在则输出File does not exist,并跳出switch语句。文件存在的话,则可以进行数据的存入了。因为数据文件具有固定的格式,即开头两行是班级名称和表头,则可以先用两次input.getline(temp,80);语句来将input设置到第三行,此时可以将数据通过input读入链表中。先用input.eof()判断文件中是否有数据,若有数据,则进行数据的读入,直到文件结束。接着要将所修改的数据文件进行保存。先提示用户输入保存文件的文件名及班级名称。文件的前两行分别是班级名称和成绩单的开头,然后通过类ofstream的一个对象output来进行学生信息的输出,一项一项的输出,并设定格式,直到输出节点为NULL为止,之后关闭output。4.1.4 查询功能模块 可以根据姓名或学号进行查找,搜索方法和前几个模块相同。通过outstu1(char *n)和outstu(char *n)来进行输出。总成绩和平均成绩的查询通过函数void outsum(char *)和void outsum1(char *)来完成。通过函数scanall()来浏览所有学生的信息。通过函数think()来进行成绩的统计分析。4.1.5 报表输出功能模块 通过建立一个新的类class stucopy用于拷贝student的数据,并实现排序功能。创建一个stucopy stuM数组,将原链表的数据拷贝于数组中,然后用选择排序方法将数组排序,然后用output按照标准的格式输出或保存为数据文件。 五、总结 本人结合教务管理人员对成绩信息的具体管理需求,开发了一套学生成绩管理系统。利用先进的计算机和网络技术对学生成绩信息进行管理,提高了教务管理人员的工作效率,减少了人力资源的浪费。本系统经多次测试,能在Visual C+ 6.0的调试环境上正常运行,基本上实现了数据管理功能,目前试运行良好。综上详细阐述了本系统的整个开发过程和实现功能,能够进行学生成绩信息录入、修改、查询、浏览、删除、统计等操作,整体界面美观大方,完成了教务人员对学生成绩管理工作的要求,适用于一系列的教育单位。本系统的应用,将会使学生和教务管理人员在第一时间内获得理想信息。该课程设计是用类来实现的。通过这个课程设计,我更加牢固地掌握了C+的知识,并对于以前不熟悉的知识有了更加深刻的了解。同时,在完成此次课程设计的过程中,我上网查找了许多与C+相关的知识,从而扩展了我的知识面。 六、参考文献 1 郑莉,董渊,何江舟.C+语言程序设计.清华大学出版社 2013-10 附件源程序清单:void main()stucopy stuM;/复制整个链表的数据于数组,用于排序stucopy stutemp;/临时变量list will;/整个链表student *p, *p1=new student(),*q;/临时变量ifstream input;/输入ofstream output;/输出char file20,classname20,temp80,id20,name9,sex110;/临时变量int m=0,n=0,j=0,i=0;/临时变量double grade15;/临时变量for(i=0;i20;i+) idi=0;for(i=0;i9;i+) namei=0;/初始化docout 学生成绩管理系统 n 0、 退出系统。n 1、 成绩的录入:包括学生学号、姓名、性别和各门课程成绩的录入。n 2、 成绩的查询:可以根据学号或姓名查询某个学生的成绩。n 3、 成绩的修改:可以根据学号或姓名来修改相应的学生的成绩。n 4、 数据的删除:可以根据学号或姓名指定删除某个学生的数据。n 5、 成绩的统计分析:包括总人数、最高成绩、最低成绩、平均成绩、n 各个分数段的人数(100-90、89-80、79-70、69-60、59-50、50以下)、及格率。n 6、 总成绩和平均成绩的查询:可以根据学号或姓名查询。n 7、 浏览所有学生信息。n 8、 将所有学生信息保存成文件。n 9、 打开指定的数据文件。n 10、 按总成绩排序输出学生信息。n 11、 按学号顺序输出学生信息,并可保存成文件。n;coutendlm;switch(m)case 1:will.instu();break;case 2:cout1.根据学号查询 2.根据姓名查询endln;switch(n)case 1:coutid;will.outstu1(id);coutn;break;case 2:coutname;will.outstu(name);coutn;break;break;case 3:cout1.根据学号查询 2.根据姓名查询endln;switch(n)case 1:coutid;will.outstu1(id);coutn;coutsetw(6)1.数学分析setw(6)2.英语setw(6)3.高等代数setw(14)4.C+语言程序设计setw(6)5.普通物理endl;coutj;will.search1(id,j);break;case 2:coutname;will.outstu(name);coutn;coutsetw(6)1.数学分析setw(6)2.英语setw(6)3.高等代数setw(14)4.C+语言程序设计setw(6)5.普通物理endl;coutj;will.search(name,j);break;break;case 4:cout1.根据学号删除 2.根据姓名删除endln;switch(n)case 1:coutid;will.outstu1(id);will.delstu1(id);break;case 2:coutname;will.outstu(name);will.delstu(name);break;break;case 5:will.think();break;case 6:cout1.根据学号查询 2.根据姓名查询endln;switch(n)case 1:coutid;will.outsum1(id);break;case 2:coutname;will.outsum(name);break;break;case 7:coutsetw(8)学号setw(8)姓名setw(6)性别setw(6)数学分析setw(6)英语setw(6)高等代数setw(14)C+语言程序设计setw(6)普通物理setw(8)总成绩setw(10)平均成绩n;will.scanall();break;case 8:cout请输入文件名:file;cout请输入班级名称:classname;output.open(file);p = will.first;outputclassname成绩单endlsetw(8)学号setw(8)姓名setw(6)性别setw(6)数学分析setw(6)英语setw(6)高等代数setw(14)C+语言程序设计setw(6)普通物理setw(8)总成绩setw(10)平均成绩next)outputsetw(8)outid()setw(8)outname()setw(6)outsex()setw(6)outgrade(0)setw(6)outgrade(1)setw(6)outgrade(2)setw(14)outgrade(3)setw(6)outgrade(4)setw(8)outsum()setw(10)outav()endl;output.close();break;case 9:cout请输入文件名:file;input.open(file);if (input.fail()coutFile does not existendl;break;input.getline(temp,80);input.getline(temp,80);if(input.eof() cout文件中无数据!idnamesex1grade10grade11grade12grade13grade14;inputtemp;inputtemp;/将总成绩和平均成绩输入进临时变量p1-setid(id);p1-setname(name);p1-setsex(sex1);p1-setgrade(grade1);will.first=p1;will.last=will.first;while(!input.eof()p=new student();q=will.last; will.last-next=p;will.last=p;inputidnamesex1grade10grade11grade12grade13grade14;will.last-setid(id);will.last-setname(name);will.last-setsex(sex1);will.last-setgrade(grade1);inputtemp;inputtemp;/将总成绩和平均成绩输入进临时变量will.last=q;will.last-next=NULL;input.close();break;case 10:p=will.first;for(i=0;inext)for (j=0;jidj;for (j=0;jnamej;for (j=0;jsexj;stui.sumsum=p-outsum();stui.average=p-outav();for(n=0;ni-1;n+)for(j=1;ji;j+)if (stun.sumsumstuj.sumsum)stutemp=stuj;stuj=stun;stun=stutemp;coutsetw(8)学号setw(8)姓名setw(6)性别setw(8)总成绩setw(10)平均成绩n;for (j=0;ji;j+)coutsetw(8)stuj.idsetw(8)setw(6)stuj.sexsetw(8)stuj.sumsumsetw(10)stuj.averageendl;break;case 11:p=will.first;for(i=0;inext)for (j=0;jidj;for (j=0;jnamej;for (j=0;jsexj;stui.sumsum=p-outsum();stui.average=p-outav();for(j=0;jgradej;for(n=0;ni-1;n+)for(j=1;jstuj.id)stutemp=stuj;stuj=st

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论