给定N个学生的基本信息,包括学号(由5个数字组成的字符串)、姓名(长度小于10的不包含空白字符的非空字符串)和3门课程的成绩([0,100]区间内的整数),要求输出总分最高学生的姓名、学号和总分(最高分只有1个)。 输入格式:输入在一行中给出正整数N(≤10)。随后N行,每行给出一位学生的信息,格式为“学号 姓名 成绩1 成绩2 成绩3”,中间以空格分隔。 输出格式:在一行中输出总分最高学生的姓名、学号和总分,间隔一个空格。题目保证这样的学生是唯一的。 输入样例: 5 00001 huanglan 78 83 75 00002 wanghai 76 80 77 00003 shenqiang 87 83 76 10001 zhangfeng 92 88 78 21987 zhangmeng 80 82 75 输出样例: 10001 zhangfeng 258
时间: 2024-02-29 22:53:12 浏览: 116
部分IT公司笔试算法题
这是一道简单的模拟题,可以使用结构体存储学生信息,然后遍历一遍统计总分最高的学生。下面是 C++ 的代码实现:
```cpp
#include <iostream>
#include <string>
using namespace std;
const int N = 10;
struct Student {
string id, name;
int score[3], sum;
} stu[N];
int main() {
int n;
cin >> n;
for (int i = 0; i < n; i++) {
cin >> stu[i].id >> stu[i].name;
for (int j = 0; j < 3; j++) {
cin >> stu[i].score[j];
stu[i].sum += stu[i].score[j];
}
}
int max_sum = 0, max_idx = 0;
for (int i = 0; i < n; i++) {
if (stu[i].sum > max_sum) {
max_sum = stu[i].sum;
max_idx = i;
}
}
cout << stu[max_idx].id << " " << stu[max_idx].name << " " << max_sum;
return 0;
}
```
这里定义了一个结构体 `Student`,每个结构体变量存储一个学生的信息。然后用一个循环读入所有学生的信息,并计算他们的总分。接着再用一个循环遍历所有学生,找到总分最高的学生,输出其信息即可。
阅读全文