C++成绩管理系统实验报告含源代码Word格式文档下载.docx
《C++成绩管理系统实验报告含源代码Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《C++成绩管理系统实验报告含源代码Word格式文档下载.docx(31页珍藏版)》请在冰点文库上搜索。
用户在确定以录入的成绩无误之后,可以将学生信息以每一班为单位存为一个数据文件。
用户输入的学生信息可随时保存数据文件。
4.文件打开功能模块
用户可以用此模块将数据文件在程序中打开、编辑,程序只能对当前打开的数据文件进行编辑。
5.查询功能模块
在此模块里,用户可实现以下操作:
1.浏览所有学生信息;
2.按学号查询学生信息;
3.按姓名查询学生信息;
4.查询一个班每个人的总成绩和平均成绩;
5.查询一个班某一门课每个人的总成绩和平均成绩;
6)进行成绩的统计分析:
包括总人数,每门课的最高成绩、最低成绩、平均成绩、各个分数段的人数(100-90、89-80、79-70、69-60、59-50、50以下)、及格人数。
6.报表输出功能模块
在此模块中,用户可以浏览所有学生的信息,或者可以按学号输出一个班学生信息:
也可以按总成绩输出从高到低输出学号、姓名信息。
模块图:
三、详细设计
主要功能模块的算法设计思路:
1.用户输入模块设计
提示用户输入一个0~11的值,并存储在一个整型变量m中。
2.学生信息录入模块设计
通过应用list中的instu()函数,来新建一个链表中的节点,即一个新的学生信息,来进行成绩的录入功能。
成绩修改功能,可以根据姓名或学号进行查询并修改相应的课程的成绩,使用了voidsearch(chars[10],int)和voidsearch1(chars[20],int)函数进行操作。
search函数根据姓名查找,search1函数根据学号进行查找。
因为学号和姓名,都是存储在字符数组中的,所以都是通过字符串的比较进行查找的。
然后根据整形参数进行对应的课程成绩的修改。
成绩删除功能,也是可以根据姓名或学号进行删除,查询的算法和成绩修改功能的查询方法是一样的,当找到要删除的节点时,因为节点都是在堆内存中保存的,所以可以直接delete掉,并将前一个节点的next指针指向被删掉的节点的next指针所指向的节点。
先提示用户输入保存文件的文件名及班级名称。
文件的前两行分别是班级名称和成绩单的开头,然后通过ofstream变量output来进行学生信息的输出,一项一项的输出,并设定格式,直到输出节点为NULL为止,之后关闭output。
先提示用户输入要打开的数据文件的名称,然后通过一个ifstream变量input来进行文件操作。
首先判断文件是否存在,如果不存在则输出"
Filedoesnotexist"
,并跳出switch语句。
文件存在的话,则可以进行数据的存入了。
因为数据文件具有固定的格式,即开头两行是班级名称和表头,则可以先用两次input.getline(temp,80);
语句来将input设置到第三行,此时可以将数据通过input读入链表中。
先用input.eof()判断文件中是否有数据,若有数据,则进行数据的读入,直到文件结束。
5.查询功能模块
可以根据姓名或学号进行查找,搜索方法和前几个模块相同。
通过outstu1(char*n)和outstu(char*n)来进行输出。
总成绩和平均成绩的查询通过函数voidoutsum(char*)和voidoutsum1(char*)来完成。
通过函数scanall()来浏览所有学生的信息。
通过函数think()来进行成绩的统计分析。
6.报表输出功能模块
通过建立一个新的类classstucopy用于拷贝student的数据,并实现排序功能。
创建一个stucopystu[M]数组,将原链表的数据拷贝与数组中,然后用选择排序方法将数组排序,然后用output按照标准的格式输出或保存为数据文件。
四、程序结构
源代码:
#include<
iostream.h>
string.h>
iomanip.h>
fstream.h>
constintM=20;
classstucopy//此类用于拷贝student的数据,用于排序功能的实现
{
public:
charid[20];
charsex[10];
charname[10];
doublegrade[5];
doublesumsum;
//总成绩
doubleaverage;
//平均成绩
};
classstudent//用于保存学生信息的类
friendclasslist;
charid[20];
//保存学号
charsex[10];
//保存性别
charname[10];
//保存名字
doublegrade[5];
//保存成绩
student()
next=0;
for(inti=0;
i<
20;
i++)id[i]=0;
for(i=0;
10;
i++)sex[i]=0;
i++)name[i]=0;
}
voids();
voidsetid(charid1[20])
for(inti=0;
i++)
id[i]=id1[i];
voidsetsex(charsex1[10])
sex[i]=sex1[i];
voidsetname(charname1[10])
name[i]=name1[i];
voidsetgrade(doublegrade1[5])
5;
grade[i]=grade1[i];
student*next;
//next指向下一个学生,构成链表
char*outid(){returnid;
char*outsex(){returnsex;
char*outname(){returnname;
doubleoutsum()
doublesum=0;
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:
请输入英语成绩:
grade[1];
case3:
请输入政治成绩:
grade[2];
case4:
cout<
请输入程序设计基础成绩:
cin>
grade[3];
case5:
请输入物理成绩:
grade[4];
}
s()//用于录入学生的信息
cout<
请输入学号:
cin>
id;
请输入姓名:
name;
请输入性别:
sex;
请输入数学成绩:
classlist//此类为链表
private:
doublehigh[5],low[5];
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;
ok\n"
}}}
voidlist:
instu()
{student*p=newstudent();
p->
s();
if(first==0){first=last=p;
}else{last->
next=p;
last=p;
outstu(char*n)
if(first==0){cout<
班级无成员!
查无此人!
endl;
return;
student*temp=first;
for(;
temp!
=NULL;
temp=temp->
next)
if(strcmp(temp->
outname(),n)==0)
{
setw(8)<
学号"
姓名"
setw(6)<
性别"
数学"
setw(6)
<
英语"
政治"
setw(14)<
程序设计基础"
物理"
temp->
outid()<
outname()<
outsex()<
<
outgrade(0)<
outgrade
(1)<
outgrade
(2)<
setw(14)
outgrade(3)<
outgrade(4);
return;
outstu1(char*n)
outid(),n)==0)
intlist:
delstu(char*n)
无数据!
return0;
student*p;
if(strcmp(first->
{first=first->
cout<
\n删除成功\n"
elsefor(;
next!
{if(strcmp(temp->
next->
{p=temp->
next=temp->
deletep;
}}
\n查无此人,删除失败\n"
return0;
delstu1(char*n)
elsewhile(temp->
=NULL)
elsetemp=temp->
think()
inti=0;
student*p=first;
while(p!
p=p->
i++;
totoal=i;
人数:
数学\n"
最高分:
hi(0)<
"
最低分:
lo(0)<
平均分:
av(0);
ev(0);
英语\n"
hi
(1)<
lo
(1)<
av
(1);
ev
(1);
政治\n"
hi
(2)<
lo
(2)<
av
(2);
ev
(2);
程序设计基础\n"
hi(3)<
lo(3)<
av(3);
ev(3);
物理\n"
hi(4)<
lo(4)<
av(4);
ev(4);
doublelist:
hi(inti)
high[i]=0.00;
student*temp=first;
while(temp!
{if(temp->
outgrade(i)>
high[i])
high[i]=temp->
returnhigh[i];
lo(inti)
low[i]=100;
outgrade(i)<
low[i])
low[i]=temp->
returnlow[i];
av(inti)
doubleaver=0;
while(temp!
aver+=temp->
temp=temp->
aver/totoal<
ev(inti)
{inta=0,b=0,c=0,d=0,e=0,f=0;
{switch((int)temp->
outgrade(i)/10)
case10:
a++;
case9:
case8:
b++;
case7:
c++;
case6:
d++;
case5:
e++;
default:
f++;
100-90的人数:
a<
89-80的人数:
b<
79-70的人数:
c
69-60的人数:
d<
59-50的人数:
e<
50以下的人数:
f
及格的人数:
(a+b+c+d)<
不及格的人数:
(e+f)<
search(chars[10],intn)
if(strcmp(temp->
outname(),s)==0)temp->
intgrade(n);
search1(chars[20],intn)
outid(),s)==0)temp->
outsum(char*n)
{
总成绩"
setw(10)<
平均成绩"
setw(8)
outsum()<
setw(10)<
outav();
return;
}
outsum1(char*n)
doubleav=0;
out