课程设计报告书学生成绩管理系统最新范本模板.docx
《课程设计报告书学生成绩管理系统最新范本模板.docx》由会员分享,可在线阅读,更多相关《课程设计报告书学生成绩管理系统最新范本模板.docx(30页珍藏版)》请在冰豆网上搜索。
![课程设计报告书学生成绩管理系统最新范本模板.docx](https://file1.bdocx.com/fileroot1/2023-2/1/80413022-5462-47bb-951f-0052c672c412/80413022-5462-47bb-951f-0052c672c4121.gif)
课程设计报告书学生成绩管理系统最新范本模板
C++语言程序设计
题目:
学生成绩管理系统
班级:
1101111
学号:
110111104
姓名:
田恬
指导教师:
王家宁
周期:
2012—7—2-2012—7-6
成绩:
年月日
一、课程设计的目的与要求
(一)课程设计目的与任务
通过本课程设计的实践,全面总结C++课程学习中的的数据类型、程序结构、数组、函数、指针、结构体等基本概念,掌握其使用方法.掌握面向对象程序设计中有关类、对象、继承、重载、多态性、输入输出流类体系、文件操作的基本概念,初步学会用类与对象这种面向对象的程序设计方法编写应用程序。
培养使用面向对象的程序设计方法编写计算机程序的能力。
(二)题目要求
1)依次录入学生信息:
学号,班级,姓名,科目,成绩并生成一个.txt文件。
2)可根据学号查询该学生的相关成绩.也可根据科目查询所有学生该课的成绩.
3)可以查询某门课成绩在某一范围内的学生的相关信息,如:
物理成绩在50~60之间。
4)可添加或删除某个学生的相关信息。
二、设计正文
1、系统分析
(1)学生信息录入功能
1)用户从键盘输入每个学生的信息:
学号、姓名、性别、数学、英语、政治、程序设计基础、物理五门课成绩。
2)可插入一个或多个学生信息到当前编辑的班级数据中。
3)可删除一个或多个学生信息.
(2)文件保存功能
1)学生信息每一班存为一个数据文件,数据文件可在程序中打开、编辑和重新保存。
2)用户输入学生信息可随时保存数据文件。
(3)文件打开功能
1)程序只能对当前打开的数据文件进行编辑。
(4)查询功能
1)浏览所有学生信息;
2)按学号查询学生信息;
3)按姓名查询学生信息;
4)查询一个班总成绩和平均成绩;
5)查询一个班某一门课总成绩和平均成绩;
6)查询某一门课分数段(〈60,60—69,70-79,80—89,>90)学生数。
(5)报表输出功能
1)按学号输出一个班学生信息:
学号、姓名、性别、数学、英语、政治、程序设计基础、物理成绩和总成绩,到屏幕和文件。
2)按总成绩输出从高到低输出学号、姓名信息。
注:
以上功能以菜单形式供用户使用,并有一定的容错功能。
2。
功能详细描述及框图:
1)输入模块
用户据菜单提示结合自己的需求输入一个0~11的值,来实现一定的功能。
2)信息录入模块
此模块可以让用户从键盘输入每个学生的信息:
学号、姓名、性别、数学、英语、政治、程序设计基础、物理五门课成绩。
用户可插入一个或多个学生信息到当前编辑的班级数据中.用户可删除一个或多个学生信息.
3)保存功能模块
用户在确定以录入的成绩无误之后,可以将学生信息以每一班为单位存为一个数据文件.用户输入的学生信息可随时保存数据文件。
4打开功能模块
用户可以用此模块将数据文件在程序中打开、编辑,程序只能当前打开的数据文件进行编辑。
5)功能模块
此模块里,用户可实现以下操作:
1.浏览所有学生信息;2.按学号查询学生信息;3.按姓名查询学生信息;4。
查询一个班每个人的总成绩和平均成绩;5.查询一个班某一门课每个人的总成绩和平均成绩;6)进行成绩的统计分析:
包括总人数,每门课的最高成绩、最低成绩、平均成绩、各个分数段的人数(100—90、89-80、79-70、69—60、59-50、50以下)、及格人数。
6)输出功能模块
在此模块中,用户可以浏览所有学生的信息,或者可以按学号输出一个班学生信息:
学号、姓名、性别、数学、英语、政治、程序设计基础、物理成绩和总成绩,到屏幕和文件。
也可以按总成绩输出从高到低输出学号、姓名信息.
系统功能框图如下:
执行流程图如下:
3、数据库设计
4、主要功能逻辑过程和实现算法
1)生成。
txt文件的算法:
cout〈<”\n输入1。
将上述信息保存成文件;输入0:
返回”<cin〉>m;
if(m==1)
{
cout〈〈"请输入文件名:
"〈cin>〉file;
cout<<"请输入班级名称:
"〈cin〉〉classname;
output.open(file);
output<〈classname<〈”成绩单”<setw(6)<<”英语”〈〈setw(6)〈〈”政治"〈〈
setw(14)<〈”程序设计基础”<setw(10)〈<”平均成绩”<for(j=0;j〈i;j++)
output〈name<〈grade[0]<〈setw(6)〈grade[2]<〈setw(14)
<〈stu[j].grade[3]〈〈output.close();
}break;
2)部分主函数体:
voidmain()
{
stucopystu[M];
stucopystutemp;
listwill;
student*p,*p1=newstudent(),*q;
ifstreaminput;
ofstreamoutput;
charfile[20],classname[20],temp[80],id[20],name[9],sex1[10];
intm=0,n=0,j=0,i=0;
doublegrade1[5];
for(i=0;i〈20;i++)id[i]=0;
for(i=0;i<9;i++)name[i]=0;
5、界面设计
主界面如图
(1):
用户将程序运行后,出现如图主界面,输入相应阿拉伯数字执行对应功能。
图
(1)主界面
6、系统测试
1)数据录入
运行程序,出现主界面,按提示输入数字1,进行数据录入,图
(2)。
图
(2)数据录入
三、小组成员分工说明
独立完成
四、课程设计总结或结论
1课程设计过程中出现的技术难点和解决方法:
1、文件的写入与读出,刚开始对文件的操作不太明白,一致不能很好的操作文件,其中最大的问题是对已存在的文件读取问题,通过“显示全部学生成绩”将数据从文件中读取,可是在使用过程中总是出现读出错误,出现乱码。
2、内存的分配问题,这也是困惑了我好久的问题.对于我们初学者来说对内存的分配和释放问题是比较抽象和模糊的难题,本来使用链表的方式存储数据,然而待到排序时出现了交换数据困难的问题,以及分配空间繁琐释放空间不及时的问题,造成空间浪费使得程序运行效率低的问题。
因此最后采用了顺序存储记录的方式,这样就能改变前述问题。
整个调试过程中主要是这么几个问题,其余的是一些小问题,很容易的就调试出来了。
2课程设计期间的主要收获:
一个星期的课程设计,虽然有些疲劳和困倦,但带给我很多的收获.C++已经学了一个学期了,有许多知识都存在似懂非懂的现象,这种现象通过实际的上机操作,已经减少了许多.对这些知识也有了更深的理解和很好的掌握.也有很多理论上说得过去的代码,但到了实际操作,却是行不通的。
这种困惑,有许多已经通过实际操作解决了,并能够深刻认识,但也有很多没有明白。
只能避过这些方法,换方法实现.在课程设计之前,因为有了综合实验的经验与教训,明白了写代码这一步是非常重要的,因为当你把代码输入电脑,并用编译器将其运行,发现通过不了,再来检查找出问题,这是一件非常辛苦的事情,也很浪费时间。
于是在课程设计的时候,我花了两天的时间来规划与写代码,将要实现的内容分析清楚,才把代码输入电脑。
我觉得写程序,应该先找到该程序中的核心地方,用多种方法来实现该核心,这才可能避免等到发现逻辑上或者编译器不支持上的错误,才来想补救的措施,这样花费时间在想补救措施是很不值得的。
附:
源代码如下:
#includeh〉
#include〈string.h>
#include〈iomanip.h>
#include〈fstream.h〉
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<〈"请输入政治成绩:
\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<<"请输入政治成绩:
\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<<”班级无成员!
查无此人!
"<〈endl;return;}
student*temp=first;for(;temp!
=NULL;temp=temp->next)
if(strcmp(temp—>outname(),n)==0)
{
cout<〈setw(8)〈〈”学号”<〈setw(8)〈〈"姓名"〈〈<”英语"<cout<outname()〈〈〈temp->outgrade(0)〈〈setw(6)〈(1)〈〈setw(6)<outgrade
(2)<〈setw(14)
〈〈temp—〉outgrade(3)<〈setw(6)〈outgrade(4);return;}
cout<〈”查无此人!
”<〈endl;
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〈〈<”英语”〈〈setw(6)<<"政治"<cout〈〈outgrade(0)〈outgrade
(1)<(2)〈〈setw(14)
<outgrade(3)〈〈setw(6)<〈temp->outgrade(4);return;}
cout〈〈”查无此人!
"〈〈endl;
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<〈"人数:
"<〈i<cout〈〈"数学\n";
cout〈〈"最高分:
”〈"〈〈lo(0)〈〈"”〈<”平均分:
”;
av(0);
ev(0);
cout<<”英语\n”;
cout<<”最高分:
”〈(1)〈<””<<"最低分:
”<〈lo
(1)〈<"”〈<"平均分:
";
av
(1);
ev
(1);
cout<〈”政治\n";
cout〈〈"最高分:
”〈(2)〈<”"<<"最低分:
”<(2)<〈””<〈”平均分:
”;
av
(2);
ev
(2);
cout〈<"程序设计基础\n”;
cout<<”最高分:
”〈〈hi(3)〈〈”"<<”最低分:
”<〈lo(3)〈〈"”<〈"平均分:
";
av(3);
ev(3);
cout〈<”物理\n";
cout<〈”最高分:
”〈〈hi(4)〈<"”〈〈”最低分:
"〈〈lo(4)〈〈”"<<"平均分:
”;
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<〈aver/totoal<〈endl;
}
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++