学生考勤管理系统课程设计报告Word文件下载.docx
- 文档编号:15363822
- 上传时间:2022-10-29
- 格式:DOCX
- 页数:32
- 大小:503.89KB
学生考勤管理系统课程设计报告Word文件下载.docx
《学生考勤管理系统课程设计报告Word文件下载.docx》由会员分享,可在线阅读,更多相关《学生考勤管理系统课程设计报告Word文件下载.docx(32页珍藏版)》请在冰豆网上搜索。
修改很简单,仅需要对该学生的某个部分进行替换即可。
采用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()
一定范围查找学生信息
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型
type=type;
//缺课类型
}
voidset(recordre)
date.assign(re.date);
cname.assign(ame);
sname.assign(re.sname);
cno=o;
type=re.type;
stringdate,cname,sname;
intcno,type;
};
classrecords//实现学生旷课情况排序的类
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<
n;
i++)
{
flag=0;
for(j=0;
j<
k;
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;
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旷课次数"
endl;
for(i=0;
cout<
s[i]<
\t\t"
c[i]<
voidorder_c()//课程排序
inti,j;
s[0].assign(r[0].cname);
for(j=0;
if(r[i].cname==s[j])
s[k]=r[i].cname;
课程名\t旷课人次"
\t"
record*r;
intn;
把所有的学生记录都保存到一个文件里面,然后根据需要再将里面需要查找的元素进行查找,相应的排序可能就是将他们尽可能压进关联式容器map,有的部分就压入set里面,这些都是根据模块的功能来选定的。
可以这么说,选择好合理的数据结构查找与排序就可以一劳永逸了。
这点在后面部分会有详细的说明。
还有就是对各功能子函数的编写应用。
五、类设计
系统中主要涉及了两个类:
一个是classrecord//关于学生考勤基本信息类
另一个是classrecords//实现学生旷课情况排序的类
六、主要算法设计
关键算法:
旷课情况的排序:
classrecords//实现学生旷课情况排序的类
旷课记录的修改:
cout<
请输入要修改缺课记录的学生姓名:
"
flush;
stringt1,t3,t4;
chartmp[30];
intt2,t5,flag=0;
cin>
>
tmp;
t1.assign(tmp);
for(i=0;
r->
if(r->
r[i].sname==t1)
flag=7;
break;
if(!
查无此学生!
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;
旷课项目的修改!
请输入要修改的项目:
\n(1.缺课日期2.缺课节次3.缺课名称4.学生姓名5.缺课类型6.全部)"
e0:
flag;
switch(flag)
case1:
gotoe1;
case2:
gotoe2;
case3:
gotoe3;
case4:
gotoe4;
case5:
gotoe5;
case6:
default:
gotoe0;
用到的知识点有:
函数的作用域、函数的调用、数组赋值、函数循环、以及类的定义,另外还用到了for函数、getch函数、switch函数、case函数、default函数等等。
七、主要代码
第一部分:
学生考勤管理系统
#include"
stdlib.h"
hanshushixian.h"
record.h"
#include<
string>
iostream>
iomanip>
fstream>
usingnamespacestd;
intmain()
c1:
//主菜单实现
system("
cls"
);
{
*************************************************************"
***★欢迎访问学生考勤管理系统★***"
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 学生 考勤 管理 系统 课程设计 报告