学生考勤管理系统课程设计报告

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

一.需求分析

功能需求:

1、录入学生的缺勤记录;

2、修改某个学生的缺勤记录;

3、查询某个学生的缺勤情况;

4、统计某段时间内,缺勤学生学号及缺勤次数,按缺勤权值统计学生的负分值,并能进行排序;

5、统计某段时间内,有学生旷课的课程及旷课人次,按旷课人次由多到少排序;

6、系统以菜单方式工作

数据需求

本系统主要涉及的数据有学生缺课信息类和有关信息排序类。学生缺课信息包括缺课时间,学生姓名,课程名称,第几节,学生迟到次数,早退次数,请假次数,旷课次数。有关信息排序类包括对课程排序和对姓名排序。

性能需求

要求系统具有可靠性,速度要快

二、系统的主要功能

(1)、录入学生的缺课记录,函数代码void input(records *r){}模块中。首先提示用户按照正确的格式进行学生缺课记录的录入,这个步骤比较简单,只需要不断地将记录的每个数据项存入结构体对应的成员中。

(2)、修改某个学生的缺课记录,函数代码void edt(records *r){}模块中。首先必须查找到你所需要修改的那位的学生全部缺课记录。这个模块不需要定义新的结构体。在修改前当然要检查记录是否为空了,不为空的话,可以设置下面这五个菜单供用户选择:1、缺课日期2、第几节课3、课程名称4、学生姓名5、缺课类型6、退出修改程序并返回系统主菜单。修改很简单,仅需要对该学生的某个部分进行替换即可。采用switch语句很快就解决。最后实现对所选记录的修改,完成后更新原有的学生记录。

(3)、查询某个学生的缺课情况,函数代码void search(records *r){}模块中。达到查询结果按照日期升序排序,同一天内按照所缺课程的时间升序排序的目的,

(4)、统计,函数代码为void order_c(){}和void order_s(){}的类模块中。其中实现对课程排序和对学生姓名的排序。

三、流程图

学生考勤系统结构图:

四、数据结构设计

此程序运用多种条件语句,主体采用的是动态数组、指针。系统的设计采用了数组语句、选择语句和循环语句,在需要处理大量同类数据时,这样就使程序书写更加简洁。程序使用了布尔函数。选择语句多采用if多分支选择结构与switch语句。首先计算switch表达式,然后在caes子句中寻找值相等的常量表达式,并以此为入口符号,由此开始顺序执行。循环语句采用了for语句等、do-while语句,for语句用于已知循环次数的循环结构,括号中的三个量分别用来表示循环变量初值、循环终值和循环增量。do-while语句先循环后判断, Break 语句在switch语句中,保证多分支情况的正确执行,在循环语句中,强制终止本层循环。保存和读取函数是典型的函数功能,一个程序是由若干个函数组成的,保存和读取函数是和其他函数互相调用的

再有使用有关类的设计,学生缺课信息类和有关信息排序类,如下:

class record //学生缺课信息类

{

public:

void set(string d,int cno,string c,string s,int type)

{

date.assign(d);//日期

cname.assign(c);//课程名字

sname.assign(s);//学生姓名

this->cno=cno;//对缺课类型的选择为int型

this->type=type;//缺课类型

}

void set(record re)

{

date.assign(re.date);

cname.assign(ame);

sname.assign(re.sname);

this->cno=o;

this->type=re.type;

}

string date,cname,sname;

int cno,type;

};

class records //实现学生旷课情况排序的类{

public:

records() //构造函数

{

r=new record[100];

n=0;

}

void order_s() //姓名的排序

{

int i;

int j;

string *s=new string[n];

int *c=new int [n];

s[0].assign(r[0].sname);

c[0]=1;

int k=1,flag;

for( i=1;i

{

flag=0;

for( j=0;j

if(r[i].sname==s[j])

{

c[j]++;

flag=1;

break;

}

if(!flag)

{

s[k]=r[i].sname;

c[k++]=1;

}

}

for(i=1;i

for( j=i;j>0;j--)

{

if(c[j]>c[j-1])

{

int tmp=c[j];

c[j]=c[j-1];

c[j-1]=tmp;

string stmp=s[j];

s[j]=s[j-1];

s[j-1]=stmp;

}

}

cout<<"旷课学生姓名\t旷课次数"<

for(i=0;i

cout<

}

void order_c() //课程排序

{

int i,j;

string *s=new string[n];

int *c=new int [n];

s[0].assign(r[0].cname);

c[0]=1;

int k=1,flag;

for( i=1;i

{

flag=0;

for(j=0;j

if(r[i].cname==s[j])

{

c[j]++;

flag=1;

break;

}

if(!flag)

{

s[k]=r[i].cname;

c[k++]=1;

}

}

for(i=1;i

相关文档
最新文档