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

发布 2022-10-04 12:54:28 阅读 3417

一.需求分析。

功能需求: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)

void set(record re)

string date,cname,sname;

int cno,type;

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

public:

records() 构造函数。

void order_s() 姓名的排序。

for(i=1;ifor( 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;icout< }

void order_c() 课程排序。

for(i=1;ifor( 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;icout< }

record *r;

int n;

把所有的学生记录都保存到一个文件里面,然后根据需要再将里面需要查找的元素进行查找,相应的排序可能就是将他们尽可能压进关联式容器map,有的部分就压入set里面,这些都是根据模块的功能来选定的。可以这么说,选择好合理的数据结构查找与排序就可以一劳永逸了。这点在后面部分会有详细的说明。

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

五、类设计。

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

一个是class record //关于学生考勤基本信息类。

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

六、主要算法设计

关键算法:旷课情况的排序:

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

public:

records() 构造函数。

if(!flag)

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<<"请输入要修改的项目:(1.缺课日期 2.缺课节次 3.缺课名称 4.学生姓名 5.缺课类型 6.全部) "e0:

cin>>flag;

switch(flag)

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

七、主要**。

第一部分:学生考勤管理系统。

#include ""

#include ""

#include ""

#include

#include

#include

#include

using namespace std;

#include ""

int main()

c1: /主菜单实现。

system("cls");

cout<<

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

合肥学院。计算机科学与技术系。课程设计报告。2010 2011学年第二期。2011年7月。学生考勤管理系统。目录。一。需求分析 3 1.1 功能需求 3 1.2 数据需求 3 1.3 性能需求 3 二。算法设计 3 2.1设计思想 3 2.2功能实现 7 三 用户手册 7 四。调试及测试 8 五。总...

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

信息科学与技术学院。程序设计基础课程设计报告。题目名称 学生考勤管理系统 学生姓名 郭晨晨。学号 2013508093 专业班级 13级计科 3 班。指导教师 郭理。2013年6月6日。目录。目录 1 1.课程设计题目与要求 2 1.1 课题目的和要求 2 1.3 课题意义 2 2 总体设计 3 2...

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

c语言趣味应用 课程设计报告。设计题目学生管理系统 系别信息技术学院 班级 11网络工程 物联网方向 姓名杨浩瑞。学号 111124088 目录。1.功能描述 3 2.概念设计 4 3.详细设计 5 4.效果及存在的问题 7 5.心得 11 6.参考文献 11 本程序能简单的对学生的各项信息进行管理...