37,744
社区成员




输入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
这道题可以通过结构体排序来实现。首先需要定义一个结构体,用于存储每个学生的姓名、成绩和平均成绩。然后读入数据,计算每个学生的平均成绩,并将所有学生信息存储在数组中。最后按照平均成绩从高到低进行排序并输出。
以下是代码实现:
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
struct Student {
string name;
int score[3];
double avg;
};
bool cmp(Student a, Student b) {
if (a.avg != b.avg) {
return a.avg > b.avg; // 先按照平均成绩从高到低排序
} 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;
for (int j = 0; j < 3; j++) {
cin >> stu[i].score[j];
}
stu[i].avg = (stu[i].score[0] + stu[i].score[1] + stu[i].score[2]) / 3.0; // 计算平均成绩
}
sort(stu, stu + n, cmp); // 按照平均成绩从高到低排序
for (int i = 0; i < n; i++) {
cout << stu[i].name << " ";
for (int j = 0; j < 3; j++) {
cout << stu[i].score[j] << " ";
}
printf("%.2f\n", stu[i].avg); // 输出平均成绩,保留两位小数
}
}
return 0;
}
输入:
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.00
zhangsan 80 75 65.00
lisi 65 52 56.00
wangliu 88 86 95.00
wangwu 87 86 95.00
zhangsan 80 75 65.00
qisi 78 77 56.00
zisi 78 77 56.00
lisi 65 52 56.00