注意事项:
- 考0分和缺考是两回事,考0分输出0,但缺考输出-1,但map函数默认映射值为0,所以当学生期中考试成绩为0时,这里选择一个大于100的非法成绩作为标记,以便后面进行识别学生到底是考了0分还是缺考;
- 成绩G的四舍五入;
- 合格者的最基本条件:在线成绩大于20;一定有期末成绩。
输入样例:
6 6 7
01234 880
a1903 199
ydjh2 200
wehu8 300
dx86w 220
missing 400
ydhfu77 99
wehu8 55
ydjh2 98
dx86w 88
a1903 86
01234 39
ydhfu77 88
a1903 66
01234 58
wehu8 84
ydjh2 82
missing 99
dx86w 81
输出样例:
missing 400 -1 99 99
ydjh2 200 98 82 88
dx86w 220 88 81 84
wehu8 300 55 84 84
#include<iostream>//标准输入输出
#include<map>//根据学生ID映射学生成绩
#include<vector>//将合格者的数据进行了堆栈
#include<algorithm>//对合格者进行排序用到sort
using namespace std;
typedef struct upone {//对于成绩合格者,将其各成绩进行保存并堆栈
string ID;
int P, M, N;
int G;
}upone;
bool cmp(upone a, upone b) {//对合格者进行排序
if (a.G == b.G) {
return a.ID < b.ID;
}
return a.G > b.G;
}
int main(){
int P, M, N;//P(做了在线编程作业的学生数)、M(参加了期中考试的学生数)、N(参加了期末考试的学生数)。每个数都不超过10000。
cin >> P >> M >> N;
map<string, int>stu[3];//存储学生的三个成绩情况
vector<upone>up;//对合格者进行堆栈存储
upone one;
string ID;
for (int i = 0; i < P; i++) {
cin >> ID >> stu[0][ID];
}
for (int i = 0; i < M; i++) {
cin >> ID >> stu[1][ID];
if(0==stu[1][ID])
stu[1][ID]=101;//考0分和缺考是两回事,考0分输出0,但缺考输出-1,但map函数默认映射值为0,所以当学生期中考试成绩为0时,这里选择一个大于100的非法成绩作为标记,以便后面进行识别学生到底是考了0分还是缺考
}
for (int i = 0; i < N; i++) {
cin >> ID >>stu[2][ID] ;
if(stu[0][ID]<200||stu[2][ID]<33 ) continue;//在线成绩不合格或期末成绩少于33,则肯定不合格,不需要往下执行
if(stu[1][ID] ==101)stu[1][ID] = 0;//没有这一句,第四个测试点通不过。
else if (stu[1][ID] > 101 || stu[1][ID] <= 0)
stu[1][ID] = -1;
int G=stu[1][ID] < stu[2][ID]? stu[2][ID]:stu[1][ID] * 0.4 + stu[2][ID] * 0.6+0.5;//四舍五入
if (G >59 ) {
one.ID = ID;
one.P = stu[0][ID];
one.M = stu[1][ID];
one.N = stu[2][ID];
one.G = G;
up.push_back(one);
}
}
sort(up.begin(), up.end(), cmp);//按照相应输出规则对合格者进行排序
for (int j = 0; j < up.size(); j++) {
cout << up[j].ID << " "<< up[j].P << " "<< up[j].M << " "<< up[j].N << " "<< up[j].G << endl;
}
return 0;
}
注意事项:
1.考0分和缺考是两回事,考0分输出0,但缺考输出-1,但map函数默认映射值为0,所以当学生期中考试成绩为0时,这里选择一个大于100的非法成绩作为标记,以便后面进行识别学生到底是考了0分还是缺考;
2.成绩G的四舍五入;
3.合格者的最基本条件:在线成绩大于20;一定有期末成绩。