2012-2013学年第二学期《高级语言程序设计》课程设计报告题目:学生考勤管理系统专业:计算机科学与技术班级:12(2)班姓名:李天栋指导教师:孙淮宁成绩:计算机与信息工程系2013年6月30日目录1设计内容及要求 (3)1.1设计内容 (3)1.2设计任务及具体要求 (3)2概要设计 (4)2.1该系统的功能简介 (4)2.2 总体程序框图 (4)2.3各个模块之间的主要关系 (5)3设计过程或程序代码 (5)3.1各个模块的程序流程图及运行界面 (5)3.2对关键代码加以分析说明 (10)4程序调试分析 (14)5小结 (17)致谢 (17)参考文献 (17)附:源程序 (18)1 设计内容及要求1.1设计内容学生考勤信息记录了学生的缺课情况,它包括:缺课日期、第几节课(连续用begin-end 的形式表示)、课程名称(课程名称中不会出现空格)、学生姓名、缺课类型(迟到、早退、请假及旷课)。
1.2设计任务及具体要求任务:(1)给出软件结构,说明各模块的功能。
(2)设计相关的类,并说明该类的作用。
特别要用图形说明类之间的继承关系。
(3)编写代码具体要求:(1)定义相关的数据,比如:学生学号学生姓名课程名称上课时间到课时间出勤状态 [旷课/病假/事假/迟到/早退](2)能够进行以下操作:A.能够对数据进行增、删、改、查操作。
B.能够按学号顺序列出某一课程的出勤状况2 概要设计2.1系统的功能简介考勤管理系统,有以下功能:(1).录入学生的缺课记录:从键盘输入数据(提示:为避免重复从键盘输入数据,测试时可将数据存储在文件中,利用输入重定向功能读入),输入格式为:缺课日期第几节课课程名称学生姓名缺课类型每行一条纪录。
例如:2013-04-29 2-4 中国近现代文学史李云龙迟到2013-04-28 2-4 大学生社交礼仪马志鹏旷课(2).修改某个学生的缺课记录:可以对缺课纪录的任意部分进行修改,然后显示一下修改后的纪录。
(3).查询某个学生的缺课情况:查询结果按照日期升序排序,同一天内按照所缺课程的时间升序排序。
(4).统计某段时间内(以天为单位),旷课学生姓名及旷课节数,查询结果先按旷课节数降序排序,旷课节数相同的学生按姓名升序排序;(5).统计某段时间内,有学生旷课的课程及旷课人次,按旷课人次由多到少排序,旷课人次相同的课程按课程名称升序排序。
2.2 总体程序框图2.3各个模块之间的主要关系本程序用结构体新定义一种数据类型,系统包含一个主函数和6个子函数(insert(),check(),rivise(),Delete(),output(),deleteallchain()),6个子函数分别用来插入、查询、修改、删除、输出、收回动态分配的空间,在主函数中通过调用子函数来实现所需功能。
3 设计过程或程序代码3.1各个模块的程序流程图及运行界面学生考勤管理系统中四个类的类层次图为:图2 学生考勤管理系统中中四个类的类层次图学生考勤管理系统中各功能模块的实现:图3 学生考勤管理系统中菜单函数的功能图1、学生缺课信息录用功能模块:图4 学生缺课信息录入的功能2、修改某学生缺课信息功能的模块图图5 学生考勤管理系统修改学生缺课信息功能图3 查询某学生缺课信息功能图:图6 学生考勤管理系统查询学生缺课信息功能图4、统计某段时间内旷课学生姓名及旷课节数功能模块:图7统计某段时间内旷课学生姓名及旷课节数功能图5、统计某段时间内,有学生旷课的课程及旷课人次功能模块图8统计某段时间内,有学生旷课的课程及旷课人次功能图图9 学生考勤管理系统中四个类的UML图3.2对关键代码加以分析说明#include<iostream.h>#include<string.h>#include<iomanip.h>struct chuqin{ //用结构体定义一个新的数据类型出勤chuqinchar name[10],number[20],subject[15],time1[15],time2[15],zhuangtai[10];chuqin *next;};//------------------------------------------------------------------------------------ void insert(chuqin* &head1)//创建单向链表并插入数据{chuqin *n;//定义一个chuqin类型指针nwhile(1)//一个死循环{n=new chuqin;//用new运算符动态分配一个chuqin空间给指针ncout<<"请依次输入姓名、学号、课程、上课时间、到课时间、出勤状态(第一个字母输入N表示结束插入):\n";//输出提示信息cin>>n->name;//输入姓名if(n->name[0]=='N') //判断刚才输入的第一个字母是否为N{delete n;//若输入的第一个字母为N,则用delete运算符收回刚才动态分配的空间break;//跳出死循环,结束插入}cin>>n->number>>n->subject>>n->time1>>n->time2>>n->zhuangtai;//若条件不满足,则继续输入学号、课程、上课时间到课时间等if(!head1) head1=n,n->next=NULL;/*假如head指针为空,则直接让head指针指向n指向的存储空间(head=n),将n->next赋值为空,即不指向任何存储空间*/else n->next=head1,head1=n;//若head指针非空,则将n指向的存储空间插在最前面}}//------------------------------------------------------------------------------------ void check(chuqin *head)//子函数实现查询功能{char number1[10];//定义一个字符串数组name1临时存放要查询的姓名int flag=1;cout<<"请输入要查询的学号:";//输出提示信息cin>>number1;//输入要查询的学号while(head)//用while循环检索查询是否有匹配的姓名{if(strcmp(number1,head->number)==0) //用函数strcmp()判断是否有匹配姓名{if(flag){ cout<<"找到!\n"<<setw(12)<<"姓名"<<setw(12)<<"学号"<<setw(12)<<"课程";cout<<setw(12)<<"上课时间"<<setw(12)<<"到课时间"<<setw(12)<<"出勤状态\n";}/*若条件为真,则输出提示信息*/cout<<setw(12)<<head->name<<setw(12)<<head->number<<setw(12)<<head->subject;cout<<setw(12)<<head->time1<<setw(12)<<head->time2<<setw(12)<<head->zhuangtai<<endl;flag=0;}head=head->next;//更新head指针,是它指向下一个chuqin类型的存储空间}if(flag) cout<<"未找到!";//假如flag值为1,则输出"未找到!"}//------------------------------------------------------------------------------------ void rivise(chuqin *head)//定义子函数实现修改功能{ char name1[10];//定义一个字符串数组name1临时存放要修改的姓名cout<<"请输入修改的姓名:";//输出提示信息cin>>name1;//输入要查询的姓名while(head){if(strcmp(name1,head->name)==0){ cout<<"找到此人!\t"<<"请输入此人新的信息(依次为:课程、上课时间、到课时间、出勤状态)\n";cin>>head->subject>>head->time1>>head->time2>>head->zhuangtai;//输入新的课程、上课时间、到课时间break;}head=head->next;}if(head==NULL) cout<<"未找到此人!无法修改!\n";}//------------------------------------------------------------------------------------ void Delete(chuqin* &head)//定义子函数实现删除功能{ char name1[10];int flag=1;chuqin *p1=NULL,*p2,*p3=head;cout<<"请输入要删除的姓名:";cin>>name1;while(head){if(strcmp(name1,head->name)==0){cout<<"找到此人!\t将此人的全部信息删除\n";if(p1==NULL){p1=head;head=head->next;delete p1;}else if(p2->next==NULL){ p1->next=NULL;delete p2;head=p3;}else{ p1->next=p2->next;delete p2;head=p3;}flag=0;break;}p1=head;head=head->next;p2=head;}if(flag){cout<<"未找到此人!无法删除!\n";}}//------------------------------------------------------------------------------------ void output(chuqin *head)//定义子函数实现输出功能{if(head==NULL) cout<<"记录为空!";else{ cout<<"所有的记录依次为:\n"<<setw(12)<<"姓名"<<setw(12)<<"学号"<<setw(12)<<"课程"; cout<<setw(12)<<"上课时间"<<setw(12)<<"到课时间"<<setw(12)<<"出勤状态\n";}while(head){cout<<setw(12)<<head->name<<setw(12)<<head->number<<setw(12)<<head->subject;cout<<setw(12)<<head->time1<<setw(12)<<head->time2<<setw(12)<<head->zhuangtai<<endl;head=head->next;}}//-----------------------------------------------------------------------------------------------void deleteallchain(chuqin *head)//定义子函数来收回所有动态分配的存储空间{chuqin *p;while(head){ p=head;head=head->next;delete p;}}//------------------------------------------------------------------------------------ void main()//主函数{int a;//定义一个整型变量chuqin *head ;//定义一个head指针head=NULL;while(1)//死循环{cout<<"请输入一个数字(1表示插入,2表示查询,3表示修改,";cout<<"4表示删除,5表示输出,6表示跳出整个程序)\n";//输出提示信息cin>>a;//输入一个整型值if(a==6) break;//若该值为6则跳出整个循环switch(a)//若a值不为6,执行一下程序{case 1: insert(head);break;case 2: check(head);break;case 3: rivise(head);break;case 4: Delete(head);break;case 5: output(head);break;default: cout<<"输入有误,请重新输入\n";/*若输入的a值不符合要求,则输出提示信息*/}}deleteallchain(head);//调用函数deleteallchain()收回所有动态分配的存储空间}4 设计结果与分析系统调试程序编写完成后,我进行了程序调试。