对于在中国大学MOOC(http://www.icourse163.org/ )学习“数据结构”课程的学生,想要获得一张合格证书,必须首先获得不少于200分的在线编程作业分,然后总评获得不少于60分(满分100)。总评成绩的计算公式为 G=(Gmid−term×40%+Gfinal×60%),如果 Gmid−term>Gfinal;否则总评 G 就是 Gfinal。这里 Gmid−term 和 Gfinal 分别为学生的期中和期末成绩。
现在的问题是,每次考试都产生一张独立的成绩单。本题就请你编写程序,把不同的成绩单合为一张。
输入在第一行给出3个整数,分别是 P(做了在线编程作业的学生数)、M(参加了期中考试的学生数)、N(参加了期末考试的学生数)。每个数都不超过10000。
接下来有三块输入。第一块包含 P 个在线编程成绩 Gp;第二块包含 M 个期中考试成绩 Gmid−term;第三块包含 N 个期末考试成绩 Gfinal。每个成绩占一行,格式为:学生学号 分数。其中学生学号为不超过20个字符的英文字母和数字;分数是非负整数(编程总分最高为900分,期中和期末的最高分为100分)。
打印出获得合格证书的学生名单。每个学生占一行,格式为:
学生学号 Gp Gmid−term Gfinal G
如果有的成绩不存在(例如某人没参加期中考试),则在相应的位置输出“−1”。输出顺序为按照总评分数(四舍五入精确到整数)递减。若有并列,则按学号递增。题目保证学号没有重复,且至少存在1个合格的学生。
解题思路: 使用STL中的map来去寻找相同字符串;
将map中的数据放入vector中使用sort排序;
实现代码:
#include<iostream> #include<string> #include<map> #include<vector> #include<algorithm> using namespace std; typedef struct grade { string id; int gp=-1; int gm=-1; int gf=-1; int ga = 0; }sg; bool cmp(sg s1, sg s2) { if (s1.ga > s2.ga) return 1; else if (s1.ga == s2.ga) return s1.id < s2.id; return 0; } int main(void) { map<string, sg> g; string s; int p, m, n, r; cin >> p >> m >> n; for (int i = 0; i < p; i++) { cin >> s >> r; if (r >= 200) g[s].gp = r; } for (int i = 0; i < m; i++) { cin >> s >> r; g[s].gm = r; } for (int i = 0; i < n; i++) { cin >> s >> r; g[s].gf = r; } vector<sg> v; for (map<string, sg>::iterator it = g.begin(); it != g.end(); it++) { int ga; if (it->second.gp >= 200) { if (it->second.gm > it->second.gf) ga = it->second.gm*0.4 + it->second.gf*0.6 + 0.5; else ga = it->second.gf; if (ga >= 60) { it->second.ga = ga; it->second.id = it->first; v.push_back(it->second); } } } sort(v.begin(), v.end(),cmp); for (int i = 0; i < v.size(); i++) cout << v[i].id <<" "<<v[i].gp <<" " << v[i].gm << " " << v[i].gf << " " << v[i].ga << endl; }