1、/*题目:学生考勤管理系统 考勤信息记录了学生的缺课情况,它包括:缺课日期、第几节课(连续多节课用 begin-end 的形式表示)、课程名称(课程名称中不会出现空格)、学生姓名、缺课类型(迟到、早退、请假及旷课)。试设计一考勤管理系统,使之能提供以下功能: 1 录入学生的缺课记录:从键盘输入数据(提示:为避免重复从键盘输入数据,测试时可将数据存储在文件中,利用输入重定向功能读入),输入格式为: 缺课日期 第几节课 课程名称 学生姓名 缺课类型 每行一条纪录。 例如: 2008-04-29 3-4 C+程序设计实验 张三 迟到 2008-04-28 3-4 C+程序设计 李四 旷课 2修改某个
2、学生的缺课记录:可以对缺课纪录的任意部分进行修改。 3查询某个学生的缺课情况:查询结果按照日期升序排序,同一天内按照所缺课程的时间升序排序。 4统计某段时间内(以天为单位),旷课学生姓名及旷课节数,查询结果先按旷课节数降序排序,旷课节数相同的学生按姓名升序排序; 5统计某段时间内,有学生旷课的课程及旷课人次,按旷课人次由多到少排序,旷课人次相同的课程按课程名称升序排序; 6系统以菜单方式工作。 通过几天的奋斗终于将这个设计做出来了,如下是该程序的详细过程*/#include #include #include #include #include #include #include #inclu
3、de using namespace std; struct Student_info int year,month,day,lesson1,lesson2; std:string course,name,type; std:istream& read(std:istream&); ; istream& Student_info:read(istream& in) inyearmonthdaylesson1lesson2coursenametype; return in; istream& read_record(istream& in,vector& s)/第一个模块-输入学生的缺课记录 S
4、tudent_info record; s.clear();/调用s.clear()来清空s的记录 while(record.read(in) s.push_back(record); in.clear();/将记录的错误状态恢复正确,以继续读取记录 return in; bool is_empty(vector& s)/判断输入学生的记录是否为空,为空则返回真 return s.empty(); bool compare(Student_info& x,Student_info& y)/按照时间排序,若日期相等则看课程时间 if(x.year=y.year&x.month=y.month&x
5、.day=y.day) return x.lesson1y.lesson1; else if(x.year=y.year&x.month=y.month&x.day!=y.day) return x.dayy.day; else if(x.year=y.year&x.month!=y.month) return x.monthy.month; else return x.yeary.year; bool time(const Student_info& stud,int y1,int m1,int d1,int y2,int m2,int d2)/筛选符合输入时间段的数据 if (y1 = s
6、tud.year & stud.month = m1 & stud.day d2) return 0; else if (y1 = stud.year & stud.month m2) return 0; else if (y1 stud.year | y2 stud.year) return 0; else return 1; void rewrite(vector& s)/第二个模块-修改某个学生的缺课情况 if(!is_empty(s) int n,m,j,k; mapstring,vector s_name; mapstring,vector :iterator ix2; vector
7、:iterator ix,iter,itera; string name;/-定义这些参数和迭代器必须在SWITHC外,不然它可能被忽略跳过 while(true) cout *endl; cout * 1.请输入你要修改缺课记录的学生姓名 *endl; cout * *endl; cout * 2.返回上一级菜单 *endl; cout *endl; coutn; if(n=1) s_name.clear();/-清空MAP容器 for(ix=s.begin();ix!=s.end();+ix) s_name(*ix).name.push_back(*ix); s.clear(); cout
8、name; coutendl; if(s_name.find(name)!=s_name.end() ix2=s_name.find(name); /-找到符合名字要求的数据,并显示出 for(iter=(*ix2).second.begin();iter!=(*ix2).second.end();+iter) cout(*iter).year-(*iter).month-(*iter).dayt; cout(*iter).lesson1-(*iter).lesson2; coutt(*iter).courset(*iter).namet(*iter).typeendl; itera=(*ix
9、2).second.begin(); coutj; for(k=0;k!=j-1;+k) +itera; cout *endl; cout * 需要更改的项目 *endl; cout * *endl; cout * 1 日期 2 节次 3 课程名称 4 姓名 5 缺课类型 6 返回上一级 *endl; cout * *endl; cout *endl; coutm; switch(m) case 1: cout(*itera).year(*itera).month(*itera).day; break; case 2: cout(*itera).lesson1(*itera).lesson2;
10、 break; case 3: cout(*itera).course; break; case 4: cout(*itera).name; break; case 5: cout(*itera).type; break; case 6: break; default: cout你的选择错了,请看清楚!second.begin();iter!=ix2-second.end();iter+) s.push_back(*iter); else cout没有这个学生的缺课记录endl; coutendl; break; else if(n=2) return ; else cout你的选择错了,请看
11、清楚!endl; else cout记录为空,没有学生的缺课记录!endl; void Search_record(vector& s)/第三个模块-查找某学生的缺课情况 if(!is_empty(s) int i; vector:iterator iter; mapstring,vector :iterator it1; mapstring,vector s_name; mapstring, vector :iterator itera; vector:iterator it; string name; while(true) cout *endl; cout * *endl; cout *
12、 1 输入你要查询的学生姓名 2 返回上一级 *endl; cout * *endl; cout *endl; couti; if(i=1) s_name.clear(); for(it=s.begin();it!=s.end();+it) s_name(*it).name.push_back(*it); for(itera=s_name.begin();itera!=s_name.end(); +itera) sort(itera-second.begin(),itera-second.end(),compare); coutname; coutendl; if(s_name.find(na
13、me)!=s_name.end() it1=s_name.find(name); for(iter=(*it1).second.begin();iter!=(*it1).second.end();+iter) cout(*iter).year-(*iter).month-(*iter).dayt; cout(*iter).lesson1-(*iter).lesson2; coutt(*iter).courset(*iter).namet(*iter).typeendl; else cout没有这个学生.endl; coutendl; else if(i=2) return ; else cou
14、t对不起,没有这个选项!endl; else cout没有这个学生的缺课记录endl; struct Search_struct string name,course; int times; ;/定义另一个结构模块 bool compare2(Search_struct& x,Search_struct& y)/按照次数排序,次数相等的则按照名字排序 if(x.times=y.times) return x.namey.times; void Search_s_t(vector& std)/第四个模块-查找某段时间内旷课学生姓名及旷课节数 if(!is_empty(std) vector:it
15、erator it; vector:iterator itera; map:iterator iter; vector vec; int y1,m1,d1,y2,m2,d2; map ret; cout请输入你要查找的一个时间段(y1 m1 d1 y2 m2 d2): y1m1d1y2m2d2; for(it=std.begin();it!=std.end();+it) if(time(*it,y1,m1,d1,y2,m2,d2) retit-name+=(it-lesson2-it-lesson1+1); for(iter=ret.begin();iter!=ret.end();iter+)
16、 Search_struct tmp; tmp.name=iter-first; tmp.times=iter-second; vec.push_back(tmp); sort(vec.begin(),vec.end(),compare2); for(itera=vec.begin();itera!=vec.end();itera+) coutnamettimesendl; else cout对不起,没有你要查找的记录!endl; void Search_c_t(vector& std)/第五个模块-查找某段时间内旷课的课程及旷课人次 if(!is_empty(std) vector:iter
17、ator it; vector:iterator itera; map:iterator iter; vector vec; int y1,m1,d1,y2,m2,d2; map ret; cout请输入你想要查找的时间段(y1 m1 d1 y2 m2 d2): y1m1d1y2m2d2; for(it=std.begin();it!=std.end();+it)/建立map容器 if(time(*it,y1,m1,d1,y2,m2,d2) retit-course+=1; for(iter=ret.begin();iter!=ret.end();iter+) Search_struct tm
18、p; tmp.course=iter-first; tmp.times=iter-second; vec.push_back(tmp); sort(vec.begin(),vec.end(),compare2); for(itera=vec.begin();itera!=vec.end();itera+) coutcoursettimesendl; else cout这段时间内没有学生的缺课纪录!endl; int main() vector stu; int choice; while(true) cout *endl; cout * 学生考勤管理系统 *endl; cout * endl;
19、 cout * 1. 录入学生的缺课记录 *endl; cout * *endl; cout * 2. 修改某个学生的缺课记录 *endl; cout * *endl; cout * 3. 查找某学生的缺课情况 *endl; cout * *endl; cout * 4. 查找某段时间内旷课学生姓名及旷课节数 *endl;cout * *endl; cout * 5. 查找某段时间内旷课的课程及旷课人次 *endl;cout * *endl; cout * 6. 退出系统 *endl; cout *endl; coutchoice; if(choice=1) cout请输入数据: endl年
20、月 日 节次 姓名 课程名称 缺课类型 endl; read_record(cin,stu); coutendl; else if(choice=2) rewrite(stu); coutendl; else if(choice=3) Search_record(stu); coutendl; else if(choice=4) Search_s_t(stu); coutendl; else if(choice=5) Search_c_t(stu); coutendl; else if(choice=6) return 0; else cout对不起,没有这个菜单项!endl; return
21、0; 5771001803090012095 5790368228596330825771001803090012386 5761373997357606965771001803090013594 5780775799025155125771001803090012387 5771649826018180515771001803090012138 5721311921589183265771001803090012359 5790368223610760535771001803090012356 5761352861437917425771001803090012355 57508786970
22、469327917088100343355274 10122994432583337917088100343355275 10186673293883200817088100343356107 10158115250150052217088100343356108 10100018005987173217088100343354295 10107419414268701717088100343356184 10187866086962880217088100343356185 10177583117408667417088100343356109 10108601437357284617088100343356110 10115220721601491617088100343355237 10102704160570270917088100343355238 10122936486142541417088100343356169 10186220440263571817088100343354928 101760654089788804