以下是一个简单的C语言程序,用于实现班级成绩排名系统。该程序会从用户那里获取班级中所有学生的成绩,然后根据成绩进行排序,并输出排名前五的学生姓名和成绩。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
// 学生结构体
struct Student {
char name[20];
int score;
};
// 比较函数,用于排序
int cmp(const void *a, const void *b) {
struct Student *s1 = (struct Student *)a;
struct Student *s2 = (struct Student *)b;
return s2->score - s1->score; // 降序排列
}
int main() {
struct Student students[100]; // 存储所有学生信息
int n, i;
printf("请输入班级人数:");
scanf("%d", &n);
printf("请输入%d个学生的姓名和成绩:\n", n);
for (i = 0; i < n; i++) {
scanf("%s %d", students[i].name, &students[i].score);
}
qsort(students, n, sizeof(struct Student), cmp); // 排序
printf("排名前五的学生是:\n");
for (i = 0; i < 5; i++) {
printf("%d. %s %d\n", i+1, students[i].name, students[i].score);
}
return 0;
}
该程序首先定义了一个学生结构体,用于存储学生姓名和成绩。然后定义了一个比较函数cmp
,用于按照成绩对学生进行排序。在主函数中,程序首先从用户那里获取班级人数和所有学生的信息,然后使用qsort
函数对所有学生进行排序,最后输出排名前五的学生信息。