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 用c语言
时间: 2024-03-17 20:46:35 浏览: 64
以下是用 C 语言实现的代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_N 100
struct Student {
char name[11];
int score[3];
double avgScore;
};
int cmp(const void *a, const void *b) {
struct Student *s1 = (struct Student *)a;
struct Student *s2 = (struct Student *)b;
if (s1->avgScore != s2->avgScore) {
return s2->avgScore > s1->avgScore ? 1 : -1;
} else {
return strcmp(s1->name, s2->name);
}
}
int main() {
int n;
while (scanf("%d", &n) != EOF) {
struct Student stu[MAX_N];
for (int i = 0; i < n; i++) {
scanf("%s %d %d %d", 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;
}
qsort(stu, n, sizeof(struct Student), cmp);
for (int i = 0; i < n; i++) {
printf("%s %d %d %d %.2f\n", stu[i].name, stu[i].score[0], stu[i].score[1], stu[i].score[2], stu[i].avgScore);
}
}
return 0;
}
```
以上代码使用结构体存储学生信息,使用 qsort() 函数对学生数组按照平均分和姓名进行排序并输出。注意在输出学生姓名时需要使用字符串。