C语言班级学生成绩管理系统项目设计.doc
《C语言班级学生成绩管理系统项目设计.doc》由会员分享,可在线阅读,更多相关《C语言班级学生成绩管理系统项目设计.doc(109页珍藏版)》请在冰豆网上搜索。
任务1:
“班级学生成绩管理系统”总体规则设计
项目的整体框架设计应当充分的进行调查研究,充分与用户进行沟通,充分了解用户的需要,在此基础上给出项目的总体规则设计方案。
这里给出了“班级学生成绩管理系统”工作模块图,其目的是给一个实例,同学们可模仿画出学校的学生成绩管理工作模块图。
任务2:
“班级学生成绩管理系统”中相关数据设计
“班级学生成绩管理系统”中的数据分常量与变量、简单类型数据和复杂类型数据。
一、常量
在“班级学生成绩管理系统”中我们假定本系统能处理一个班40个学生的数据。
用符号常量来定义一个班的学生人数。
定义方法:
#defineSTUNUM40
二、变量
“班级学生成绩管理系统”中的学生信息主要包括:
学号、性别、年龄、三门功课成绩、总成绩和平均成绩,再加上一些与计算全班成绩有关的最高成绩、最低成绩等。
这些变量是简单类型变量,还有一些复杂类型变量,如数组、结构体、共用体、指针类型等变量。
1.简单类型
intstunum;//整数类型的学号
charstusex;//字符类型的性别
intstuage;//整数类型的年龄
floatscore1;//单精度类型的成绩1
floatscore2;//单精度类型的成绩2
floatscore3;//单精度类型的成绩3
floatavescore;//单精度类型的平均成绩
floatmaxscore;//单精度类型的最高分
floatminscore;//单精度类型的最低分
2.复杂类型
charname[10];//数组类型的姓名
structstudent
{
intstunum;//学号
charname[10];//姓名
charstusex;//性别
intstuage;//年龄
floatscore[3];//三门成绩
}stu[STUNUM];//含有40个学生的结构体数组
另外,在编程实践中还会遇到一些这里不能一一列举出来的变量和指针变量,我们将在后续的学习逐渐认识与掌握。
任务3:
用输入输出函数初步设计项目封面与菜单
本任务采用C语言的标准输入输出函数分别实现“班级学生成绩管理系统”的封面和主、子菜单,这些内容暂时处理成单个程序的形式,后面将介绍如何将这些封面与主、子菜单组合起来。
在下述程序中使用了system函数,这个函数是一个库函数,它能发出一个MS-DOS命令,括号中是cls是MS-DOS的清屏命令,通过system函数执行了一条DOS命令。
这里给出了封面、主菜单、编辑子菜单、显示子菜单、计算子菜单、排序子菜单六个程序,这六个程序是各自独立的程序。
1.项目封面源程序
2.项目主菜单源程序
3.项目编辑子菜单源程序
4.项目显示子菜单源程序
5.项目计算子菜单源程序
6.项目排序子菜单源程序
程序执行后的效果图如下:
1.项目封面效果图
2.项目主菜单效果图
3.项目编辑子菜单效果图
4.项目显示子菜单效果图
5.项目计算子菜单效果图
6.项目排序子菜单效果图
任务4:
项目封面、菜单的顺序执行设计
该任务将封面和主、子菜单连接起来,实现封面、菜单的顺序执行。
由于,一个程序只有一个主函数,因此,我们将封面、主菜单、编辑子菜单、查看子菜单、计算子菜单、排序子菜单程序中的主函数分别改名为StuCover、MainMenu、EditMenu、DispMenu、CompMenu、SortMenu,并将这些函数复制到一个C程序,另外,再建立一个主函数,分别执行这些函数。
要注意的是,主函数是放在所有其他函数后面的,能不能将主函数放到所有函数前面呢?
或者主函数的位置是否可以任意呢?
回答是肯定的,关于如何实现这一点我们将在后续内容中讲解。
该任务使用了一个getch库函数,它在这里的作用是使屏幕发生暂停,当程序执行到此函数时发生暂停,等待用户输入一个任意字符后,程序继续向下执行。
这样做的好处是,可以使用户看清封面和主、子菜单。
任务5:
用if语句实现菜单的选择执行设计
顺序结构调用菜单的方法在实际应用中是很少见的。
因为,这种结构的程序控制权不在用户手中,而在程序的开发人员手中。
一个实用程序,它对菜单的控制权应当在用户。
C语言是用分支结构来实现对菜单的选择执行的。
分支结构有两种实现方法,本任务首先用if~else语句来实现菜单的选择执行。
由于任务的需要,我们将任务4原来的菜单函数稍作修改。
以主菜单为例,将MainMenu函数中的变量定义行和倒数3行全部删除,只保留子菜单显示语句,其他子菜单函数也一样操作,再重新书写主函数。
该项目实现如果输入0~6之间的整型数字,将在屏幕上打印一句话或显示相应的子菜单,由于排序子菜单是属于查看子菜单下面的子菜单,它属于三级子菜单,暂时没有显示。
另外,本任务使用了函数申明,这样可以使主函数在程序中的位置变得任意。
有了函数申明,就可以方便程序设计。
任务5源程序如下:
任务6:
用switch语句实现菜单的选择执行设计
实现菜单的选择执行还可以用更为简捷的switch语句来实现。
只要将任务5的主函数稍加修改就能实现用switch语句实现菜单的选择执行。
任务6源程序如下:
任务7:
用循环语句实现项目主菜单的选择执行设计
任务5和任务6实现了菜单的选择执行,虽然实现了用户选择执行菜单功能,但每执行一个菜单后,程序就结束了,这还是不能满足用户的需要。
用户往往需要程序在没有被用户结束之前都能被操作,即程序的控制权应当掌握在用户手中。
要实现上述功能,必须使用循环结构。
由于实现循环选择执行项目菜单是一种比较复杂结构,为了便于学习,我们首先用三种方法实现主菜单的循环选择执行,即主菜单实现循环选择,而子菜单暂时不实现循环选择。
1.用for循环实现已知循环次数的循环。
该循环规定了循环执行的次数,当循环达到规定的次数后将会退出循环。
学习者不要理解成for循环只能实现已知循环次数的循环,实际上for循环也能够实现未知循环次数的循环。
源程序如下:
任务7:
用循环语句实现项目主菜单的选择执行设计
2.用while循环实现未知循环次数的循环。
该循环只有输入了0才会退出循环,但不能显示“退出程序!
”,即当输入0后,循环再不执行,从而退出循环。
源程序如下:
任务8:
用循环语句实现项目主、子菜单的选择执行设计
本任务不但要实现主菜单的循环选择执行,而且还要实现主、子菜单的循环选择执行。
下面用while循环、do~while循环的嵌套和switch语句来实现项目主、子菜单的循环选择执行。
为了降低学习难点,本任务除执行五个菜单函数外,其他要执行的函数都用输出一句话来实现。
另外,为了使任务8更为合理,增加了退出函数Quit()的定义和相关使用。
源程序如下:
任务9:
项目整体框架设计
项目的整体框架设计是程序开发中关系重大的一环。
整体框架是程序的总体结构,是程序设计中非常重要的部分。
整体框架设计的好处是为项目搭好一个骨架,这个骨架包含了项目的各种功能模块,后面的工作就是如何完成这些功能模块,当这些功能模块全部实现后,整个项目也就完成了。
该任务是对任务8作进一步完善,实现的目标是:
1.主函数的位置可以任意放置;
2.将原来显示一句话的语句和getch()函数调用语句放置到相应函数中;
3.增加光标定位函数;
4.完善程序说明函数。
程序运行结果与任务8相似。
任务9源程序如下:
任务10:
初步实现学生成绩排序
要完成上述任务,在主函数中,我们设计一个包含10个学生成绩的实型一维数组。
定义数组的整型常量表达式用符号常量表示,然后完善相应函数。
在编写函数的过程中要十分注意函数的形参与实参的设计。
本任务初步实现按升序排列学生成绩函数AsceSort()和按降序排列学生成绩函数DropSort(),排序方法采用“冒泡法排序”。
在排序函数中,创建并生成了一个新的成绩数组(temp_score),其目的是在排序的过程中,不影响原成绩数组的排列。
在任务9的基础上实现任务10,并对任务9做如下修改:
1.在项目的文件包含行的下面增加
#defineSTUSIZE10
2.主函数稍做修改
voidmain()
{
intchoose,editnum,dispnum,compnum,sortnum;//定义5个输入变量
floatstuscore[STUSIZE]={65.5,80,97.5,55,85,77.5,89,95,68.5,88};
//定义学生成绩数组
……
}
3.函数声明修改为:
voidAsceSort(floatscore[],intstusize);//按升序排列学生成绩函数声明
voidDropSort(floatscore[],intstusize);//按降序排列学生成绩函数声明
4.函数调用语句修改为:
AsceSort(stuscore,STUSIZE);
DropSort(stuscore,STUSIZE);
5.AsceSort()和DropSort()定义的修改见源程序。
任务10源程序如下:
任务10:
初步实现学生成绩排序(函数优化)
从AsceSort函数和DropSort函数的程序代码可以看出,它们除了循环中判断条件不相同外,绝大多数内容是相同的。
我们只要稍加修改,就可以将这两个函数写成一个函数,这样即可以减轻编程者的劳动强度,又能提高程序的可读性。
我们用条件表达式来实现函数的优化。
将AsceSort函数和DropSort函数优化成一个函数,该函数名为AsceDropSort。
函数声明修改为:
voidAsceDropSort(floatscore[],intstusize,int);//按升降序排列学生成绩函数声明
函数调用修改为:
升序排列:
AsceDropSort(stuscore,STUSIZE,1);
降序排列:
AsceDropSort(stuscore,STUSIZE,0);
AsceDropSort函数源程序如下:
在这个函数中,我们增加了一个形参,根据该形参的值来确定是否按升序还是按降升序排列,然后用条件表达式来判断是执行什么排列。
其他内容不变。
同学们可以思考其他的优化方法。
任务11:
初步实现学生最高、最低等成绩查找
该任务初步实现项目中查找最高学生成绩函数SearchMax()、查找最低学生成绩函数SearchMin()、查找不合格成绩函数NotElig()。
要完成上述任务,在主函数中,我们设计一个包含10个学生成绩的实型数组。
定义数组的整型常量表达式用符号常量表示,然后完善相应函数。
在编写函数的过程中要十分注意函数的形参与实参的设计。
1.在项目的文件包含行的下面增加下列内容:
#defineSTUSIZE10
2.相应函数声明修改为:
voidSearchMax(floatscore[],intstusize);//查找最高学生成绩函数声明
voidSearchMin(floatscore[],intstusize);//查找最低学生成绩函数声明
voidNotElig(floatscore[],intstu