收藏 分销(赏)

C学生成绩标准管理系统完整.doc

上传人:w****g 文档编号:2609257 上传时间:2024-06-03 格式:DOC 页数:86 大小:1.02MB
下载 相关 举报
C学生成绩标准管理系统完整.doc_第1页
第1页 / 共86页
C学生成绩标准管理系统完整.doc_第2页
第2页 / 共86页
C学生成绩标准管理系统完整.doc_第3页
第3页 / 共86页
C学生成绩标准管理系统完整.doc_第4页
第4页 / 共86页
C学生成绩标准管理系统完整.doc_第5页
第5页 / 共86页
点击查看更多>>
资源描述

1、 课程设计说明书本科毕业设计(题 目: 学生成绩管理系统(老师端)学生姓名: 陈学 院:工学院专 业:数字媒体技术班 级:级指导老师:二一四 年 十 一月 目录一、设计题目(问题)描述和要求- 1 -二、系统分析和模块设计- 1 -三、系统设计- 1 -1. 系统总体框架- 1 -2. 系统关键算法步骤图- 1 -四、运行结果- 5 -五、小结- 5 -六、参考资料- 6 -一、设计题目(问题)描述和要求设计目标:为方便对学生成绩进行高效管理,编写该程序以提升学生成绩管理效率。使用该程序以后,学校管理者能够查询某位学生、某个科目标成绩情况,还能够对学生成绩进行排名,对学生数据进行修改和删除,其

2、中排名以按总分排名,而且还提供了多个浏览方法,查询结果包含各个科目标分数、总分。经过本系统能够很好掌握学生成绩分布,减轻管理人员负担,也使学生成绩和信息长时期保留。 问题描述:编写一个简单学生成绩管理系统。学生成绩管理系统有若干学生成绩统计组成,每个统计由学号、姓名、性别、年级、班级、三个科目成绩、总分、总排名、各科目排名多个部分组成,学号不超出5个字符,姓名不超出3个字符,成绩为int型数据。该系统含有以下功效:程序开始实施时显示以下版权信息和主菜单: *学生成绩管理系统*学生信息l *1.登记l *2.编辑 l *3.次序 l 4.删除 浏览l * 5全部l *6个人l *7考试l * 8

3、专业l *9指定系统设置 10默认 0.退出 *请输入(08): 经过键盘输入数字010后,程序能够实施对应功效,实施完后回到上述主菜单继续等候用户输入,输入数字0后退出程序。(1)选择“登记”后,输入学生个数。按程序提醒输入学号、姓名、性别、年级、班级、三个科目成绩、总分、总排名、各科目排名。(2)选择“编辑”,按提醒输入要删除学生学号,输入学号,若改学号存在,则编辑对应学生统计,假如该学号不存在,返回主菜单(3)选择“次序”后,会显示从成绩高到低还是相反。该操作会改变程序中链表连接次序,所以浏览时候显示也是次序改变后链表次序输出。(4)(5)选择“全部”,系统会根据年级显示全部学生其成绩。

4、(6)选择“个人”,系统会提醒输入学生姓名或学号进行寻求并显示。(7) 选择“考试”, 会根据每十二个月级每一次考试显示成绩。(8) 选择“专业”,会根据专业进行成绩输出。(9) 选择“指定”,里面还有八种显示方法:分数段、排名、学期、班级、大一至大四,能够根据其进行浏览。(10) 进行系统相关设置,如是否显示欢迎窗口,是否自动读取信息或是手动、是否浏览显示全部等(0)退出操作。二、系统分析和模块设计学生成绩管理系统结构图学生信息学生成绩管理系主程序统创建链表1.登记学生信息0.退出程序6.排序学生成绩5.浏览全部信息4.修改学生信息3.删除学生信息2.搜索学生信息7其它多个浏览方法8.默认设

5、置三、系统设计1. 系统总体框架学生成绩管理系统步骤图学生成绩管理系统创建链表打开student.txt、set.txt文件 创建学生对象主菜单1.登记 退出系统 2.编辑3.次序保留为文件4.删除5.全部6.个人9.指定 8.专业 7.考试10.默认设置2. 系统关键算法步骤图 (1).系统包含类库#include#include#include#include#include#include(2).主函数 main()函数 创建Manage对象象象 进入start并进行信息读取等前提操作,然后进入用户界面开始有用户选择操作(3)student类设计和分析class student/*定义学

6、生成绩类*/ private: Score *sco; string name;string pro; /专业int clas;int grade;string num;char sex;Student* next; ;表1 student类说明表名称属性说明sco数据组员成绩类开头name数据组员说明学生姓名pro数据组员说明学生专业clas数据组员说明学生班级grade数据组员说明学生年级num数据组员说明学生学号sex数据组员说明学生性别next数据组员说明指向下一个节点指针(4) .Manage类设计和分析 class List int setSET; Student* stu;pub

7、lic: /添加void Add(); /添加学生 void AddScore(Student *istudent); /添加成绩 /浏览 int isEmpty(); int infoPass(string inum,string iname,char isex,int igrade,int iclas);void SkimAll(); void SkimClas(); void SkimPro(); void SpecSkim(); /指定其它浏览方法void SkimByScore();void SkimByTerms();void SkimByPlace();void SkimByTe

8、st();void SkimByGrade(int igrade); void Find(string T); /查找void PrintAllScore(Score *q);/打印成绩,本程序用来打印第二次开始考试成绩void InitScore(); /未给出成绩学生进行 0 赋值void Delete(); /删除void Edit(string Y); /编辑void EditScore(Student *istu);void OrderConscore(); /按总成绩排序void OrderObject(); /排名次void Compare(); /比较 void Save();

9、 /保留int Read(); /读取 string OfProfe(); /选择学院专业int WINAPI WinMain(HINSTANCE hInst,HINSTANCE hPrevInstance,LPSTR lpszCmdParam,int nCmdShow); /显示欢迎对话框int countSpecStudent(int igrade); /返回指定年级学生数int countConStudent(); /返回总学生数/默认设置void DefaultSetting();/进行默认设置 void ReadSet(); /读取默认设置void SaveSet(); /保留默认设

10、置int* ReturnSet(); char ReturnjudgeOfadd();void JudgeOfSave(); /判定是否保留已修改信息void Start(); /类内部开始运行操作void Interface(); /用户使用界面;名称属性说明Add()组员函数添加学生AddScore()组员函数添加成绩isEmpty()组员函数判定是否有学生infoPass()组员函数判定输入信息正当性SkimAll()组员函数全部浏览SkimClas组员函数按班级浏览SkimPro()组员函数按专业浏览SpecSkim()组员函数其它浏览方法Find(string T)组员函数按学号寻求

11、PrintAllScore(Score *q)组员函数输出全部学生数量InitScore()组员函数初始化成绩未满学生成绩Delete()组员函数删除学生Edit(string Y)组员函数编辑学生信息EditScore(Student *istu)组员函数编辑学生成绩OrderConscore()组员函数将链表改变连接次序进而改变输出次序OrderObject()组员函数给每个学生每次考试排名次Save()组员函数保留学生信息Read()组员函数读取学生信息OfProfe()组员函数选择学生专业countSpecStudent(int igrade)组员函数返回对应年级学生数量countCo

12、nStudent()组员函数返回总学生数DefaultSetting()组员函数默认设置ReadSet()组员函数读取设置SaveSet()组员函数保留设置ReturnSet()组员函数返回设置(5).Score类名称属性说明Score()结构函数无参结构函数Score(int *sc)结构函数只含成绩结构函数Score(int *sc,int*or,int Con)结构函数含全部信息结构函数ReturnConScore()组员函数返回总分数(6). 输入学生资料模块:关键功效用来对学生成绩进行搜集和输入。在学生信息保留在系统中前提下,输入要输入人数,成绩录入需要输入学生资料,比如学号,姓名。

13、在正确输入学生资料后,就能够对该学生各科成绩进行录入。该学生各科成绩输入成功后,输入下一个学生资料时会先判定是否学号是否和之前学生相同,假如相同,则显示提醒信息,不一样则继续输入(6) 输出学生资料模块:关键功效用来对学生成绩进行输出。在系统已经录入了学生资料成绩前提下,使用该功效能够显示全部学生信息,资料等等。具体包含学生学号,姓名和各科成绩。在查看学生资料,成绩各方面信息后,按任意键就能够返回到主菜单(5)查找并显示学生资料模块关键功效是用来查找学生资料。在系统保留了某学生资料前提下,想要查找该学生资料,能够输入该学生姓名,这么系统就会显示该学生资料和各科成绩等信息(6)按学号查找,修改学

14、生资料模块关键功效是用来修改学生资料。在系统保留了某学生资料前提下,想要查找该学生资料,能够输入该学生学号,系统就会显示该学生资料和各科成绩等信息,这么就能够修改该学生资料,成绩等信息。(7)按学号查找,删除该学生资料模块关键功效是用来删除学生资料。在系统保留学生资料前提下,想删除某学生资料,能够输入学生学号,系统查找该学生资料后,就能够删除了。因为学生辍学,毕业等原因,立即对系统进行更新,删除部分没用信息,能够使系统愈加优化(8)按学生成绩总分进行排列模块关键功效是用来对学生资料按总分进行排序。在系统保留学生资料,成绩前提下,使用此功效能够对学生资料按总分进行排序,这么就方便查找成绩相同或是

15、相近同学资料。(9)储存学生资料并退出系统模块 关键功效是用来储存学生资料。在对系统进行一系列操作,比如添加、删除、修改学生资料后,对系统最新操作进行保留,立即更新系统,方便下一次操作。四、运行结果1开始界面2输入数据3 搜索数据4 删除5. 修改数据7. 显示数据8.系统设置五、小结这个程序经过了暑假开始到十月份修改编辑,要感谢老师及同学指导,另外程序本身更适合学生数量不是尤其多情况下,加入学生有上千上万个,那么应该在添加多个类,在学生类之上类,这么才能够大大方便了多种操作和浏览等。六、参考资料C+程序设计教程CSDN程序员小区代码:/*学生成绩管理系统*类:Student Score Ma

16、nage*可保留学科:语文 数学 英语*时间段:大一至大四*说明:该程序针对学生数较少情况,假如面对上千上万学生数,应该再将其中存放结构进行改变,* 分别分层次存放,比如大一至大四四个链表表头,在每一个链表中又依据不一样分类依据细分,* 比如依据学院、专业等,这么改变将大大有利于程序进行寻求、输出、排序等包含链表操作,* 当然对应代码也要稍作改变*/#include#include#include#include#include#include#include#includeusing namespace std;#define CONOBJ 3 /3科科目#define YEARS 4 /4

17、个年#define SET 4 /4个设置要求class Scorepublic:int scoreCONOBJ; /chinese,math,english三科目分别对应order0、order1、order2,每个学期两次考试,分为期中和期末考试int orderCONOBJ; /MAX科学科排名int ConOrder; /总排名Score *next; /定义在学生类当中Score()next=NULL;int i;for(i=0;iCONOBJ;i+)scorei=0;orderi=0;ConOrder=0;/无参结构函数Score(int *sc)next=NULL;int i;f

18、or(i=0;iCONOBJ;i+)scorei=*sc;orderi=0;sc+;ConOrder=0;/只有成绩结构函数Score(int *sc,int*or,int Con)next=NULL;int j;for(j=0;jCONOBJ;j+)scorej=*sc;orderj=*or;sc+;or+;ConOrder=Con;/含全部参数结构函数int ReturnConScore() /返回总分数return score0+score1+score2;/=class Student/*Student类中包含Score类*用来存放众多成绩,每个学期两次成绩, 每年两个学期*/Scor

19、e *sco; string name;string pro; /专业int clas;int grade;string num;char sex;Student* next;public:/*多个不一样参数Student结构函数重载,*分别对应不一样形式结构方法*/ Student(string iname):name(iname),next(NULL)sco=NULL; couttttt成功添加学生namen;/1.单参数时结构函数Student(string iname=No name,string ipro=none,int iclass=0,int igrade=0,string i

20、num=0,char isex=n):name(iname),num(inum),sex(isex),next(NULL),pro(ipro),clas(iclass),grade(igrade)sco=NULL; couttttt成功添加学生namen;return;/2.用于添加无输入成绩结构函数Student(string iname,string ipro,int iclas,int igrade,string inum,char isex,int *score):name(iname),pro(ipro),clas(iclas),grade(igrade),num(inum),sex

21、(isex),next(NULL)sco=new Score(score);couttttt成功添加学生namen;/3.用于添加有成绩结构函数 Student(string iname,string ipro,int iclas,int igrade,string inum,char isex,int *score,int conor,int *order):name(iname),pro(ipro),clas(iclas),grade(igrade),num(inum),sex(isex),next(NULL)sco=new Score(score,order,conor);/4.用于从文

22、件读入时候结构函数int CountOfScore(); /统计已经存放成绩数量,每个学期两次考试,每次考试算作一次成绩录入 成绩录入总计= 4*igradefriend class Manage; ;/=class Manageint setSET;Student* stu; /*统计是否实施了修改学生信息操作,等于n表示未修改信息或修改完了但已经保留,等于y表示已经修改而且还未保留*/char judgeOfAdd;public:Manage()stu=NULL;/*for(int i=0;inext;delete p;stu=NULL;Student* ReturnStu()return

23、 stu;/添加void Add(); /添加学生 void AddScore(Student *istudent); /添加成绩 /浏览 int isEmpty(); int infoPass(string inum,string iname,char isex,int igrade,int iclas);void SkimAll(); void SkimClas(); void SkimPro(); void SpecSkim(); /指定其它浏览方法void SkimByScore();void SkimByTerms();void SkimByPlace();void SkimByTe

24、st();void SkimByGrade(int igrade); void Find(string T); /查找void PrintAllScore(Score *q);/打印成绩,本程序用来打印第二次开始考试成绩void InitScore(); /未给出成绩学生进行 0 赋值void Delete(); /删除void Edit(string Y); /编辑void EditScore(Student *istu);void OrderConscore(); /按总成绩排序void OrderObject(); /排名次void Compare(); /比较 void Save();

25、 /保留int Read(); /读取 string OfProfe(); /选择学院专业int WINAPI WinMain(HINSTANCE hInst,HINSTANCE hPrevInstance,LPSTR lpszCmdParam,int nCmdShow); /显示欢迎对话框int countSpecStudent(int igrade); /返回指定年级学生数int countConStudent(); /返回总学生数/默认设置void DefaultSetting();/进行默认设置 void ReadSet(); /读取默认设置void SaveSet(); /保留默认设

26、置int* ReturnSet(); char ReturnjudgeOfadd();void JudgeOfSave(); /判定是否保留已修改信息void Start(); /类内部开始运行操作void Interface(); /用户使用界面;/=/Student名空间中组员函数函数定义int Student:CountOfScore()Score *p=sco;int i;for(i=0;p;p=p-next,i+);return i;/=/=/Manage名空间中组员函数函数定义int* Manage:ReturnSet() return set;/-char Manage:Retu

27、rnjudgeOfadd() return judgeOfAdd;/-int Manage:countSpecStudent(int igrade) /返回指定年级学生数Student *p=stu;int count=0;for(;p!=NULL;p=p-next)if(p-grade=igrade)count+;return count;/-int Manage:countConStudent() /返回总学生数int count=0;for(int i=0;iCountOfScore()grade*4) /成绩已经输入满了char judge;coutjudge;if(!(judge=Y

28、|judge=y)return ;*/int i,judge_grade,judge_term;char flag=y,judge_input=y;Score *temp;for(judge_grade=1;judge_gradegrade;judge_grade+)for(judge_term=1;judge_termjudge_input;if(judge_input=y|judge_input=Y)printf(n请输入大%d第%d次考试成绩:n,judge_grade,judge_term); /abs(istudent-CountOfScore()-(istudent-grade-1

29、)*4+1)/输入成绩int scoreCONOBJ;for(i=0;iCONOBJ;i+)if(i=0)cout输入语文成绩:;else if(i=1)cout输入数学成绩:;elsecoutscorei;temp=new Score(score);else if(judge_input=n|judge_input=N)temp=new Score(); /不输入成绩学生会自动赋分数为0elsereturn ;/返回/做连接操作if(istudent-sco=NULL)istudent-sco=temp;elseScore *p=istudent-sco;while(p-next!=NULL

30、)p=p-next;p-next=temp;temp-next=NULL;/-void Manage:Compare() /比较/-void Manage:OrderObject() /各科目成绩排名次,赋值给score类中orderif(!isEmpty()return ; Student *p,*pp;Score *qp,*qpp;int score,ch,ma,eng,igrade=1,times,count=0,c1=0,c2=0,c3=0;while(igrade=YEARS)if(countSpecStudent(igrade)=0)igrade+;continue;p=stu;t

31、imes=1; while(times grade=igrade)qp=p-sco; /qp指向该次所要排成绩学生成绩开头处for(int j=0;jnext;/qpp=qpp-next;/*初始化及更新操作*/qp-ConOrder=countSpecStudent(igrade); /不一样年级学生数for(int i=0;iorderi=qp-ConOrder; /降低函数而调用采取方法score=qp-ReturnConScore();ch=qp-score0;ma=qp-score1;eng=qp-score2;pp=stu; /每一次全部从头开始进行比较while(pp!=NULL

32、)c3+;if(pp-grade=igrade & pp-num!=p-num)qpp=pp-sco;for(int j=0;jnext;if(qpp-ReturnConScore() ConOrder-;if(qpp-score0 order0-; if(qpp-score1 order1-;if(qpp-score2 order2-;pp=pp-next;/coutnamenext;times+;igrade+;/-int WINAPI Manage:WinMain(HINSTANCE hInst,HINSTANCE hPrevInstance,LPSTR lpszCmdParam,int

33、 nCmdShow)MessageBox(NULL,/count,您好,欢迎使用!,学生成绩管理系统,MB_OK | MB_ICONINFORMATION);return 0;/-string Manage:OfProfe() /选择学院专业int kh;string i; coutnttn;couttt 1.工学院 n;coutttn;couttt 2.理学院 n;coutttn;couttt 3.医学院 n;coutttn;couttt 4.农学院 n;coutttn;couttt 5.经管学院 n;coutttn;couttt 0.退出选择 n;couttt n;docoutkh;while(!(kh=0&kh6);coutt*n;swit

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 考试专区 > 中考

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服