2024华为OD机试题库-(A卷+B卷+C卷+D卷)-(JAVA、Python、C++)
2024华为OD机试题库-(C卷+D卷)-(JAVA、Python、C++)
题目描述
小明来到某学校当老师,需要将学生按考试总分或单科分数进行排名,你能帮帮他吗?
输入描述
第 1 行输入两个整数,学生人数 n 和科目数量 m,0<n<100,0<m < 10
第 2 行输入 m 个科目名称,彼此之间用空格隔开。
- 科目名称只由英文字母构成,单个长度不超过 10 个字符。
- 科目的出现顺序和后续输入的学生成绩一一对应
- 不会出现重复的科目名称
第 3 行开始的 n 行,每行包含一个学生的姓名和该生 m 个科目的成绩 (空格隔开)。
- 学生不会重名
- 学生姓名只由英文字母构成,长度不超过 10 个字符
- 成绩是 0~100 的整数,依次对应第 2 行输入的科目
第 n+2 行,输入用作排名的科目名称。若科目不存在,则按总分进行排序。
输出描述
输出一行,按成绩排序后的学生名字,空格隔开。成绩相同的按照学生姓名字典顺序排序。
示例1
输入
3 2
yuwen shuxue
fangfang 95 90
xiaohua 88 95
minmin 100 82
shuxue
输出
xiaohua fangfang minmin
说明
按 shuxue 成绩排名,依次是 xiaohua、fangfang、minmin
示例2
输入
3 2
yuwen shuxue
fangfang 95 90
xiaohua 88 95
minmin 100 82
xiaoming
输出
fangfang xiaohua minmin
说明
按照总成绩进行排序。
考点
自定义排序
解题思路
1.按照给出科目的成绩进行降序排序,如果没给出科目,按照总成绩降序排序;
然后依次输出排完序后的学生姓名。
代码
c++
#include <bits/stdc++.h>
#include <algorithm>
#include <math.h>
using namespace std;
int index=0;
bool cmp(vector<string> a, vector<string> b) {
return stoi(a[index+1]) > stoi(b[inde