C++成绩管理 最终版.docx
- 文档编号:9615289
- 上传时间:2023-05-20
- 格式:DOCX
- 页数:32
- 大小:140.22KB
C++成绩管理 最终版.docx
《C++成绩管理 最终版.docx》由会员分享,可在线阅读,更多相关《C++成绩管理 最终版.docx(32页珍藏版)》请在冰点文库上搜索。
C++成绩管理最终版
课程设计(论文)任务书
软件 学 院 机械电子工程 专 业 2010-1 班
一、课程设计(论文)题目 学生成绩管理系统
二、课程设计(论文)工作自2011年6月27日起至2011年6月29日止。
三、课程设计(论文)地点:
软件学院实训中心
四、课程设计(论文)内容要求:
1.本课程设计的目的
(1)使学生掌握系统各功能模块的基本工作原理;
(2)掌握C++的基本编程原理和及基本的编程方法;
(3)使学生学会系统调试;
(4)培养学生分析、解决问题的能力;
(5)提高学生的软件文档写作能力。
2.课程设计的任务及要求
1)基本要求:
(1)分析系统各功能模块的工作原理;
(2)至少有查找,排序、插入、删除等功能;
(3)提出系统的设计方案;
(4)对所进行编程、调试、修改。
2)创新要求:
在基本要求达到后,可进行创新设计,如:
文件流等;
3)课程设计论文编写要求
(1)要按照书稿的规格打印誊写毕业论文
(2)论文包括目录、绪论、正文、小结、参考文献、附录等
(3)毕业论文装订按学校的统一要求完成
4)答辩与评分标准:
(1)完成原理分析:
20分;
(2)完成设计过程:
40分;
(3)完成调试运行结果正确:
25分;
(4)答辩:
15分。
5)参考文献:
(1)谭浩强.《C++程序设计实践指导》清华大学出版社
(2)谭浩强.《C++程序设计》清华大学出版社
(3)http:
//
6)课程设计进度安排
内容天数 地点
总体需求与分析构思及收集资料1 图书馆
各模块的编程实现,调试与修改3 机房
撰写论文与答辩1 图书馆,
学生签名:
2010年6月28日
课程设计(论文)评审意见
(1)完成原理分析(20分):
优( )、良( )、中( )、一般( )、差( );
(2)设计分析 (25分):
优( )、良( )、中( )、一般( )、差( );
(3)完成调试 (20分):
优( )、良( )、中( )、一般( )、差( );
(4)运行结果 (20分):
优( )、良( )、中( )、一般( )、差( );
(5)答辩 (15分):
优( )、良( )、中( )、一般( )、差( );
(6)格式规范性及考勤是否降等级:
是( )、否( )
评阅人签名:
职称:
讲师
2010年6月20日
学生成绩管理系统设计报告
一、需求分析:
用数组或链表数据结构完成一个学生成绩管理系统,此系统的具体功能要求如下:
(1)学生信息录入功能
1)用户从键盘输入每个学生的信息:
学号、姓名、性别、数学、英语、C++、程序设计、物理五门课成绩。
2)可插入一个或多个学生信息到当前编辑的班级数据中。
3)可删除一个或多个学生信息。
(2)文件保存功能
1)学生信息每一班存为一个数据文件,数据文件可在程序中打开、编辑和重新保存。
2)用户输入学生信息可随时保存数据文件。
(3)文件打开功能
1)程序只能对当前打开的数据文件进行编辑。
(4)查询功能
1)浏览所有学生信息;
2)按学号查询学生信息;
3)按姓名查询学生信息;
4)查询一个班总成绩和平均成绩;
5)查询一个班某一门课总成绩和平均成绩;
(5)报表输出功能
1)按学号输出一个班学生信息:
学号、姓名、性别、数学、英语、C++、程序设计、物理成绩和总成绩,到屏幕和文件。
2)按总成绩输出从高到低输出学号、姓名信息。
注:
以上功能以菜单形式供用户使用,并有一定的容错功能。
二、概要设计
整体框架:
整个学生成绩管理系统采用链表作为基本数据结构,创建一个类student用于保存学生的数据且是链表中的一个节点。
类list作为保存整个链表之用。
主函数通过switch语句来根据用户的需要连接各个模块,以实现用户的需要。
模块基本介绍:
1.用户输入模块
在此模块中,用户将根据菜单提示结合自己的需求输入一个0~11的值,来实现一定的功能。
2.学生信息录入模块
此模块可以让用户从键盘输入每个学生的信息:
学号、姓名、性别、数学、英语、C++、程序设计、物理五门课成绩。
用户可插入一个或多个学生信息到当前编辑的班级数据中。
用户可删除一个或多个学生信息。
3.文件保存功能模块
用户在确定以录入的成绩无误之后,可以将学生信息以每一班为单位存为一个数据文件。
用户输入的学生信息可随时保存数据文件。
4.文件打开功能模块
用户可以用此模块将数据文件在程序中打开、编辑,程序只能对当前打开的数据文件进行编辑。
5.查询功能模块
在此模块里,用户可实现以下操作:
1.浏览所有学生信息;2.按学号查询学生信息;3.按姓名查询学生信息;4.查询一个班每个人的总成绩和平均成绩;5.查询一个班某一门课每个人的总成绩和平均成绩;6)进行成绩的统计分析:
包括总人数,每门课的最高成绩、最低成绩、平均成绩、及格人数。
6.报表输出功能模块
在此模块中,用户可以浏览所有学生的信息,或者可以按学号输出一个班学生信息:
学号、姓名、性别、数学、英语、C++、程序设计、物理成绩和总成绩,到屏幕和文件。
也可以按总成绩输出从高到低输出学号、姓名信息。
模块图:
三、详细设计
主要功能模块的算法设计思路:
1.用户输入模块设计
提示用户输入一个0~11的值,并存储在一个整型变量m中。
2.学生信息录入模块设计
通过应用list中的instu()函数,来新建一个链表中的节点,即一个新的学生信息,来进行成绩的录入功能。
成绩修改功能,可以根据姓名或学号进行查询并修改相应的课程的成绩,使用了voidsearch(chars[10],int)和voidsearch1(chars[20],int)函数进行操作。
search函数根据姓名查找,search1函数根据学号进行查找。
因为学号和姓名,都是存储在字符数组中的,所以都是通过字符串的比较进行查找的。
然后根据整形参数进行对应的课程成绩的修改。
成绩删除功能,也是可以根据姓名或学号进行删除,查询的算法和成绩修改功能的查询方法是一样的,当找到要删除的节点时,因为节点都是在堆内存中保存的,所以可以直接delete掉,并将前一个节点的next指针指向被删掉的节点的next指针所指向的节点。
3.查询功能模块
可以根据姓名或学号进行查找,搜索方法和前几个模块相同。
通过outstu1(char*n)和outstu(char*n)来进行输出。
总成绩和平均成绩的查询通过函数voidoutsum(char*)和voidoutsum1(char*)来完成。
通过函数scanall()来浏览所有学生的信息。
通过函数think()来进行成绩的统计分析。
4.报表输出功能模块
通过建立一个新的类classstucopy用于拷贝student的数据,并实现排序功能。
创建一个stucopystu[M]数组,将原链表的数据拷贝与数组中,然后用选择排序方法将数组排序,然后用output按照标准的格式输出数据文件。
实践结果图
四、程序结构
源代码:
#include
#include
#include
#include
constintM=20;
classstucopy//此类用于拷贝student的数据,用于排序功能的实现
{
public:
charid[20];
charsex[10];
charname[10];
doublegrade[5];
doublesumsum;//总成绩
doubleaverage;//平均成绩
};
classstudent//用于保存学生信息的类
{
friendclasslist;
public:
charid[20];//保存学号
charsex[10];//保存性别
charname[10];//保存名字
doublegrade[5];//保存成绩
student()
{
next=0;
for(inti=0;i<20;i++)id[i]=0;
for(i=0;i<10;i++)sex[i]=0;
for(i=0;i<10;i++)name[i]=0;
}
voids();
voidsetid(charid1[20])
{
for(inti=0;i<20;i++)
id[i]=id1[i];
}
voidsetsex(charsex1[10])
{
for(inti=0;i<10;i++)
sex[i]=sex1[i];
}
voidsetname(charname1[10])
{
for(inti=0;i<10;i++)
name[i]=name1[i];
}
voidsetgrade(doublegrade1[5])
{
for(inti=0;i<5;i++)
grade[i]=grade1[i];
}
student*next;//next指向下一个学生,构成链表
char*outid(){returnid;};
char*outsex(){returnsex;};
char*outname(){returnname;};
doubleoutsum()
{
doublesum=0;
for(inti=0;i<5;i++)
sum+=this->outgrade(i);
returnsum;
}
doubleoutav(){returnthis->outsum()/5;}
doubleoutgrade(inti){returngrade[i];};
voidintgrade(int);
};
voidstudent:
:
intgrade(intj)//用于修改学生的成绩
{
switch(j)
{
case1:
cout<<"请输入数学成绩:
\n";
cin>>grade[0];break;
case2:
cout<<"请输入英语成绩:
\n";
cin>>grade[1];break;
case3:
cout<<"请输入C++成绩:
\n";
cin>>grade[2];break;
case4:
cout<<"请输入程序设计成绩:
\n";
cin>>grade[3];break;
case5:
cout<<"请输入物理成绩:
\n";
cin>>grade[4];break;
}
}
voidstudent:
:
s()//用于录入学生的信息
{
cout<<"请输入学号:
\n";
cin>>id;
cout<<"请输入姓名:
\n";
cin>>name;
cout<<"请输入性别:
\n";
cin>>sex;
cout<<"请输入数学成绩:
\n";
cin>>grade[0];
cout<<"请输入英语成绩:
\n";
cin>>grade[1];
cout<<"请输入C++成绩:
\n";
cin>>grade[2];
cout<<"请输入程序设计成绩:
\n";
cin>>grade[3];
cout<<"请输入物理成绩:
\n";
cin>>grade[4];
}
classlist//此类为链表
{
private:
doublehigh[5],low[5];
public:
student*last,*first;//链表的开头和结尾
doubletotoal;
list(){last=0;first=0;};
~list();
voidinstu();//新建一个学生的数据
voidoutstu(char*);//根据姓名输出一个学生的信息
intdelstu(char*n);//根据姓名删除一个学生的信息
voidoutstu1(char*);//根据学号输出一个学生的信息
intdelstu1(char*n);//根据学号删除一个学生的信息
voidoutsum(char*);//根据姓名输出一个学生的总成绩和平均成绩
voidoutsum1(char*);//根据学号输出一个学生的总成绩和平均成绩
voidthink();//用于输出班级成绩的统计分析
voidsearch(chars[10],int);//根据姓名修改一个学生的成绩
voidsearch1(chars[20],int);//根据学号修改一个学生的成绩
doublehi(inti);//求某门课的最高分
doublelo(inti);//求某门课的最低分
voidav(inti);//求某门课的平均分
voidev(inti);//用于班级成绩统计分析的人数分布输出
voidscanall();//输出所有学生的信息
};
list:
:
~list()//析构函数,将所有创建的学生对象删掉
{
if(first!
=0)
{
student*p=first,*temp;
while(p!
=NULL){
temp=p;
p=p->next;
deletetemp;
cout<<"ok\n";
}}}
voidlist:
:
instu()
{student*p=newstudent();
p->s();
if(first==0){first=last=p;}else{last->next=p;last=p;}
}
voidlist:
:
outstu(char*n)
{
if(first==0){cout<<"班级无成员!
查无此人!
"< student*temp=first;for(;temp! =NULL;temp=temp->next) if(strcmp(temp->outname(),n)==0) { cout< <<"英语"< cout< < (1)< (2)< < cout<<"查无此人! "< return; } voidlist: : outstu1(char*n) { if(first==0){cout<<"班级无成员! 查无此人! "< student*temp=first;for(;temp! =NULL;temp=temp->next) if(strcmp(temp->outid(),n)==0) { cout< <<"英语"< cout< < (1)< (2)< < cout<<"查无此人! "< return; } intlist: : delstu(char*n) { if(first==0){cout<<"无数据! "< student*temp=first; student*p; if(strcmp(first->outname(),n)==0) {first=first->next;deletetemp; cout<<"\n删除成功\n";return0;} elsefor(;temp->next! =NULL;temp=temp->next) {if(strcmp(temp->next->outname(),n)==0) {p=temp->next;temp->next=temp->next->next;deletep; cout<<"\n删除成功\n";return0;}} cout<<"\n查无此人,删除失败\n"; return0; } intlist: : delstu1(char*n) { if(first==0){cout<<"无数据! "< student*temp=first; student*p; if(strcmp(first->outid(),n)==0) {first=first->next;deletetemp; cout<<"\n删除成功\n";return0;} elsewhile(temp->next! =NULL) {if(strcmp(temp->next->outid(),n)==0) {p=temp->next;temp->next=temp->next->next;deletep; cout<<"\n删除成功\n";return0;} elsetemp=temp->next;} cout<<"\n查无此人,删除失败\n"; return0; } voidlist: : think() { if(first==0){cout<<"无数据! "< inti=0; student*p=first; while(p! =NULL) { p=p->next; i++; } totoal=i; cout<<"人数: "< cout<<"数学\n"; cout<<"最高分: "< "< "; av(0); ev(0); cout<<"英语\n"; cout<<"最高分: "< (1)<<""<<"最低分: "< (1)<<""<<"平均分: "; av (1); ev (1); cout<<"C++\n"; cout<<"最高分: "< (2)<<""<<"最低分: "< (2)<<""<<"平均分: "; av (2); ev (2); cout<<"程序设计\n"; cout<<"最高分: "< "< "; av(3); ev(3); cout<<"物理\n"; cout<<"最高分: "< "< "; av(4); ev(4); } doublelist: : hi(inti) { high[i]=0.00; student*temp=first; while(temp! =0) {if(temp->outgrade(i)>high[i]) high[i]=temp->outgrade(i); temp=temp->next; } returnhigh[i]; } doublelist: : lo(inti) { low[i]=100; student*temp=first;while(temp! =0) {if(temp->outgrade(i) low[i]=temp->outgrade(i); temp=temp->next; } returnlow[i]; } voidlist: : av(inti) { doubleaver=0; student*temp=first; while(temp! =NULL) { aver+=temp->outgrade(i); temp=temp->next; } cout< } voidlist: : ev(inti) {inta=0,b=0,c=0,d=0,e=0,f=0; student*temp=first;while(temp! =0) {switch((int)temp->outgrade(i)/10) { case10: a++;break;case9: a++;break; case8: b++;break;case7: c++;break; case6: d++;break;case5: e++;break; default: f++; } temp=temp->next; } cout<<"100-90的人数:
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+成绩管理 最终版 C+ 成绩 管理