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

上传人:b****1 文档编号:2446865 上传时间:2022-10-29 格式:DOCX 页数:32 大小:503.89KB
下载 相关 举报
学生考勤管理系统课程设计报告.docx_第1页
第1页 / 共32页
学生考勤管理系统课程设计报告.docx_第2页
第2页 / 共32页
学生考勤管理系统课程设计报告.docx_第3页
第3页 / 共32页
学生考勤管理系统课程设计报告.docx_第4页
第4页 / 共32页
学生考勤管理系统课程设计报告.docx_第5页
第5页 / 共32页
点击查看更多>>
下载资源
资源描述

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

《学生考勤管理系统课程设计报告.docx》由会员分享,可在线阅读,更多相关《学生考勤管理系统课程设计报告.docx(32页珍藏版)》请在冰豆网上搜索。

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

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

一.需求分析

功能需求:

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

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

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

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

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

6、系统以菜单方式工作

数据需求

本系统主要涉及的数据有学生缺课信息类和有关信息排序类。

学生缺课信息包括缺课时间,学生姓名,课程名称,第几节,学生迟到次数,早退次数,请假次数,旷课次数。

有关信息排序类包括对课程排序和对姓名排序。

性能需求

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

二、系统的主要功能

(1)、录入学生的缺课记录,函数代码voidinput(records*r){}模块中。

首先提示用户按照正确的格式进行学生缺课记录的录入,这个步骤比较简单,只需要不断地将记录的每个数据项存入结构体对应的成员中。

(2)、修改某个学生的缺课记录,函数代码voidedt(records*r){}模块中。

首先必须查找到你所需要修改的那位的学生全部缺课记录。

这个模块不需要定义新的结构体。

在修改前当然要检查记录是否为空了,不为空的话,可以设置下面这五个菜单供用户选择:

1、缺课日期2、第几节课3、课程名称4、学生姓名5、缺课类型6、退出修改程序并返回系统主菜单。

修改很简单,仅需要对该学生的某个部分进行替换即可。

采用switch语句很快就解决。

最后实现对所选记录的修改,完成后更新原有的学生记录。

(3)、查询某个学生的缺课情况,函数代码voidsearch(records*r){}模块中。

达到查询结果按照日期升序排序,同一天内按照所缺课程的时间升序排序的目的,

(4)、统计,函数代码为voidorder_c(){}和voidorder_s(){}的类模块中。

其中实现对课程排序和对学生姓名的排序。

三、流程图

学生考勤系统结构图:

 

基类的数据成员和成员描述

record

Stringdate,cname,sname;

intcno,type;

voidset();

stringtostr();

类名/函数名

描述

类名/函数名

描述

record

基类

edt()

修改学生信息

records

实现学生旷课情况排序的类

del()

删除学生信息

wt/rd()

实现对文件的输入和输出

search()

查找学生信息

input()

录入学生的缺课记录

search_s()

一定范围查找学生信息

edt()

修改学生信息

main()

主函数

四、数据结构设计

此程序运用多种条件语句,主体采用的是动态数组、指针。

系统的设计采用了数组语句、选择语句和循环语句,在需要处理大量同类数据时,这样就使程序书写更加简洁。

程序使用了布尔函数。

选择语句多采用if多分支选择结构与switch语句。

首先计算switch表达式,然后在caes子句中寻找值相等的常量表达式,并以此为入口符号,由此开始顺序执行。

循环语句采用了for语句等、do-while语句,for语句用于已知循环次数的循环结构,括号中的三个量分别用来表示循环变量初值、循环终值和循环增量。

do-while语句先循环后判断,Break语句在switch语句中,保证多分支情况的正确执行,在循环语句中,强制终止本层循环。

保存和读取函数是典型的函数功能,一个程序是由若干个函数组成的,保存和读取函数是和其他函数互相调用的

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

classrecord//学生缺课信息类

{

public:

voidset(stringd,intcno,stringc,strings,inttype)

{

date.assign(d);//日期

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

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

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

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

}

voidset(recordre)

{

date.assign(re.date);

cname.assign(ame);

sname.assign(re.sname);

this->cno=o;

this->type=re.type;

}

stringdate,cname,sname;

intcno,type;

};

classrecords//实现学生旷课情况排序的类

{

public:

records()//构造函数

{

r=newrecord[100];

n=0;

}

voidorder_s()//姓名的排序

{

inti;

intj;

string*s=newstring[n];

int*c=newint[n];

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

c[0]=1;

intk=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])

{

inttmp=c[j];

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

c[j-1]=tmp;

stringstmp=s[j];

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

s[j-1]=stmp;

}

}

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

for(i=0;i

cout<

}

voidorder_c()//课程排序

{

inti,j;

string*s=newstring[n];

int*c=newint[n];

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

c[0]=1;

intk=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

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

{

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

{

inttmp=c[j];

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

c[j-1]=tmp;

stringstmp=s[j];

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

s[j-1]=stmp;

}

}

cout<<"课程名\t旷课人次"<

for(i=0;i

cout<

}

record*r;

intn;

};

把所有的学生记录都保存到一个文件里面,然后根据需要再将里面需要查找的元素进行查找,相应的排序可能就是将他们尽可能压进关联式容器map,有的部分就压入set里面,这些都是根据模块的功能来选定的。

可以这么说,选择好合理的数据结构查找与排序就可以一劳永逸了。

这点在后面部分会有详细的说明。

还有就是对各功能子函数的编写应用。

五、类设计

系统中主要涉及了两个类:

一个是classrecord//关于学生考勤基本信息类

另一个是classrecords//实现学生旷课情况排序的类

六、主要算法设计

关键算法:

旷课情况的排序:

classrecords//实现学生旷课情况排序的类

{

public:

records()//构造函数

{

r=newrecord[100];

n=0;

旷课记录的修改:

cout<<"请输入要修改缺课记录的学生姓名:

"<

stringt1,t3,t4;

chartmp[30];

intt2,t5,flag=0;

cin>>tmp;

t1.assign(tmp);

for(i=0;in;i++)

if(r->r[i].sname==t1)

{

flag=7;

break;

}

if(!

flag)

{

cout<<"查无此学生!

"<

return;

}

t1=r->r[i].date;

t2=r->r[i].cno;

t3=r->r[i].cname;

t4=r->r[i].sname;

t5=r->r[i].type;

旷课项目的修改!

cout<<"请输入要修改的项目:

\n(1.缺课日期2.缺课节次3.缺课名称4.学生姓名5.缺课类型6.全部)"<

e0:

cin>>flag;

switch(flag)

{

case1:

gotoe1;

case2:

gotoe2;

case3:

gotoe3;

case4:

gotoe4;

case5:

gotoe5;

case6:

gotoe1;

default:

gotoe0;

}

用到的知识点有:

函数的作用域、函数的调用、数组赋值、函数循环、以及类的定义,另外还用到了for函数、getch函数、switch函数、case函数、default函数等等。

七、主要代码

第一部分:

学生考勤管理系统

#include"stdlib.h"

#include"hanshushixian.h"

#include"record.h"

#include

#include

#include

#include

usingnamespacestd;

#include"record.h"

intmain()

{

c1:

//主菜单实现

system("cls");

{

cout<<"*************************************************************"<

cout<<"***★欢迎访问学生考勤管理系统★***"<

cout<<"*************************************************************"<

cout<<

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

当前位置:首页 > 法律文书 > 起诉状

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1