C++成绩管理系统实验报告含源代码Word格式文档下载.docx

上传人:b****2 文档编号:622896 上传时间:2023-04-29 格式:DOCX 页数:31 大小:50.50KB
下载 相关 举报
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第1页
第1页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第2页
第2页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第3页
第3页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第4页
第4页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第5页
第5页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第6页
第6页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第7页
第7页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第8页
第8页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第9页
第9页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第10页
第10页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第11页
第11页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第12页
第12页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第13页
第13页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第14页
第14页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第15页
第15页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第16页
第16页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第17页
第17页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第18页
第18页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第19页
第19页 / 共31页
C++成绩管理系统实验报告含源代码Word格式文档下载.docx_第20页
第20页 / 共31页
亲,该文档总共31页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

C++成绩管理系统实验报告含源代码Word格式文档下载.docx

《C++成绩管理系统实验报告含源代码Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《C++成绩管理系统实验报告含源代码Word格式文档下载.docx(31页珍藏版)》请在冰点文库上搜索。

C++成绩管理系统实验报告含源代码Word格式文档下载.docx

用户在确定以录入的成绩无误之后,可以将学生信息以每一班为单位存为一个数据文件。

用户输入的学生信息可随时保存数据文件。

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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 工程科技 > 能源化工

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2