7-6 成绩排序 分数 10 作者 usx程序设计类课程组 单位 绍兴文理学院 输入n个学生的姓名及其3门功课成绩(整数),要求根据3门功课的平均成绩从高分到低分输出每个学生的姓名、3门功课成绩及平均成绩,若平均分相同则按姓名的字典序输出。 输入格式: 测试数据有多组,处理到文件尾。每组测试数据首先输入一个正整数n(1<n<100),表示学生人数;然后是n行信息,分别表示学生的姓名(长度不超过10且由英文字母构成的字符串)和3门课成绩(正整数)。 输出格式: 对于每组测试,输出排序后的学生信息,每行一个学生信息:姓名、3门课成绩、平均成绩(保留2位小数)。每行数据之间留一个空格。 输入样例: 3 zhangsan 80 75 65 lisi 65 52 56 wangwu 87 86 95 6 zhangsan 80 75 65 qisi 78 77 56 wangwu 87 86 95 zisi 78 77 56 wangliu 88 86 95 lisi 65 52 56 输出样例: wangwu 87 86 95 89.33 zhangsan 80 75 65 73.33 lisi 65 52 56 57.67 wangliu 88 86 95 89.67 wangwu 87 86 95 89.33 zhangsan 80 75 65 73.33 qisi 78 77 56 70.33 zisi 78 77 56 70.33 lisi 65 52 56 57.67
时间: 2024-03-17 12:46:34 浏览: 44
PTA-公因数与公约数
5星 · 资源好评率100%
这道题可以使用结构体来存储学生的信息,然后按照平均分和姓名进行排序。代码如下:
```cpp
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
struct Student {
string name;
int score[3];
double avgScore;
};
bool cmp(Student a, Student b) {
if (a.avgScore != b.avgScore) {
return a.avgScore > b.avgScore;
} else {
return a.name < b.name;
}
}
int main() {
int n;
while (cin >> n) {
Student stu[n];
for (int i = 0; i < n; i++) {
cin >> stu[i].name >> stu[i].score[0] >> stu[i].score[1] >> stu[i].score[2];
stu[i].avgScore = (double)(stu[i].score[0] + stu[i].score[1] + stu[i].score[2]) / 3;
}
sort(stu, stu + n, cmp);
for (int i = 0; i < n; i++) {
printf("%s %d %d %d %.2f\n", stu[i].name.c_str(), stu[i].score[0], stu[i].score[1], stu[i].score[2], stu[i].avgScore);
}
}
return 0;
}
```
以上代码会先输入学生人数 n,然后依次输入每个学生的姓名和三门功课成绩。计算每个学生的平均分并存储在结构体中。最后使用 sort() 函数对学生数组按照平均分和姓名进行排序,并输出排序后的结果。
阅读全文