1、一需求分析功能需求:1、录入学生的缺勤记录;2、修改某个学生的缺勤记录; 3、查询某个学生的缺勤情况; 4、统计某段时间内,缺勤学生学号及缺勤次数,按缺勤权值统计学生的负分值,并能进行排序; 5、统计某段时间内,有学生旷课的课程及旷课人次,按旷课人次由多到少排序; 6、系统以菜单方式工作数据需求本系统主要涉及的数据有学生缺课信息类和有关信息排序类。学生缺课信息包括缺课时间,学生姓名,课程名称,第几节,学生迟到次数,早退次数,请假次数,旷课次数。有关信息排序类包括对课程排序和对姓名排序。性能需求要求系统具有可靠性,速度要快二、系统的主要功能(1)、录入学生的缺课记录,函数代码 void inpu
2、t(records *r)模块中。首先提示用户按照正确的格式进行学生缺课记录的录入,这个步骤比较简单,只需要不断地将记录的每个数据项存入结构体对应的成员中。(2)、修改某个学生的缺课记录,函数代码 void edt(records *r)模块中。首先必须查找到你所需要修改的那位的学生全部缺课记录。这个模块不需要定义新的结构体。在修改前当然要检查记录是否为空了,不为空的话,可以设置下面这五个菜单供用户选择:1、缺课日期 2、第几节课 3、课程名称 4、学生姓名 5、缺课类型 6、退出修改程序并返回系统主菜单。修改很简单,仅需要对该学生的某个部分进行替换即可。采用 switch 语句很快就解决。最
3、后实现对所选记录的修改,完成后更新原有的学生记录。(3)、查询某个学生的缺课情况,函数代码 void search(records *r)模块中。达到查询结果按照日期升序排序,同一天内按照所缺课程的时间升序排序的目的,(4)、统计,函数代码为 void order_c()和 void order_s()的类模块中。其中实现对课程排序和对学生姓名的排序。三、流程图学生考勤系统结构图:2基类的数据成员和成员描述recordString date,cname,sname;int cno,type;void set() ;string tostr();类名/函数名 描述 类名/函数名 描述record
4、 基类 edt() 修改学生信息records 实现学生旷课情况排序的类del() 删除学生信息wt/rd() 实现对文件的输入和输出search() 查找学生信息input() 录入学生的缺课记录 search_s() 一定范围查找学生信息edt() 修改学生信息 main() 主函数四、数据结构设计此程序运用多种条件语句,主体采用的是动态数组、指针。系统的设计采用了数组语句、选择语句和循环语句,在需要处理大量同类数据时,这样就使程序书写更加简洁。程序使用了布尔函数。选择语句多采用 if 多分支选择结构与 switch 语句。首先计算 switch 表达式,然后在 caes 子句中寻找值相等
5、的常量表达式,并以此为入口符号,由此开始顺序执行。循环语句采用了 for 语句等、do-while 语句,for 语句用于已知循环次数的循环结构,括号中的三个量分别用来表示循环变量初值、循环终值和循环增量。do-while 语句先循环后判断,Break 语句在 switch 语句中,保证多分支情况的正确执行,在循环语句中,强制终止本层循环。保存和读取函数是典型的函数功能,一个程序是由若干个函数组成的,保存和读取函数是和其他函数互相调用的再有使用有关类的设计,学生缺课信息类和有关信息排序类,如下:class record /学生缺课信息类public:void set(string d,int
6、cno,string c,string s,int type)date.assign(d);/日期cname.assign(c);/课程名字sname.assign(s);/学生姓名this-cno=cno;/对缺课类型的选择 为 int 型this-type=type;/缺课类型3void 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 recor
7、ds /实现学生旷课情况排序的类public:records() /构造函数r=new record100;n=0;void order_s() /姓名的排序int i;int j;string *s=new stringn;int *c=new int n;s0.assign(r0.sname);c0=1;int k=1,flag;for( i=1;i0;j-)if(cjcj-1)int tmp=cj;cj=cj-1;cj-1=tmp;string stmp=sj;sj=sj-1;sj-1=stmp;cout0;j-)if(cjcj-1)int tmp=cj;cj=cj-1;cj-1=tmp
8、;string stmp=sj;sj=sj-1;sj-1=stmp;couttmp;t1.assign(tmp);for(i=0;in;i+)if(r-ri.sname=t1)flag=7;break;if(!flag)coutri.date;t2=r-o;t3=r-ame;t4=r-ri.sname;t5=r-ri.type;旷课项目的修改!coutflag;switch(flag)case 1:goto e1;case 2:goto e2;case 3:goto e3;case 4:goto e4;case 5:goto e5;case 6:goto e1;default:goto e0;
9、用到的知识点有:函数的作用域、函数的调用、数组赋值、函数循环、以及类的定义,另外还用到了 for 函数、getch 函数、switch 函数、case 函数、default 函数等等。七、主要代码第一部分:学生考勤管理系统#include “stdlib.h“#include “hanshushixian.h“#include “record.h“#include #include #include 7#include using namespace std;#include “record.h“int main()c1: /主菜单实现system(“cls“); coutchose;if(c
10、hose=7)exit(0);records *r=new records();rd(r);switch(chose)case 1:pri(r);break;8case 2:input(r);break;case 3:search(r);break;case 4:edt(r);break;case 5:del(r);break;case 6:search_s(r);break;default:goto c2;coutyn;if(yn=y)goto c1;else if(yn=n)exit(0);else goto c3;return 0;第二部分:record.h (类的设计部分)#inclu
11、de #include using namespace std;#ifndef record_class#define record_classclass 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;this-type=type;void set(record /assign 可以避免不必要的内存分配,可以提高效率cname.assign(ame);sname.a
12、ssign(re.sname);this-cno=o;this-type=re.type;9string tostr()string s;char tmp3;s.assign(date);itoa(cno,tmp,10);s.append(“#“);s.append(tmp);/直接添加另一个完整的字符串s.append(“#“);s.append(cname);s.append(“#“);s.append(sname);itoa(type,tmp,10);s.append(“#“);s.append(tmp);return s;string date;string cname;string
13、sname;int cno;int type;#endif record_class#ifndef records_class#define records_classclass records/实现学生旷课情况排序的类public:records() /构造函数r=new record100;n=0;void order_s() /姓名的排序int i;int j;string *s=new stringn;int *c=new int n;10s0.assign(r0.sname);c0=1;int k=1,flag;for( i=1;i0;j-)if(cjcj-1)int tmp=cj;cj=cj-1;cj-1=tmp;string stmp=sj;sj=sj-1;sj-1=stmp;cout“旷课学生姓名t 旷课次数“endl;for(i=0;ik;i+)coutsi“tt“ciendl;void order_c() /课程排序int i,j;string *s=new stringn;int *c=new int n;s0.assign(ame);c0=1;int k=1,flag;