编写程序,输入n个学生的学号和成绩(有1位小数),按成绩从高到低排序输出,n 小于50,学号小于10位。 C语言结构体
时间: 2023-11-28 22:48:10 浏览: 102
下面是一个使用 C 语言结构体实现学生成绩排序的程序示例:
```c
#include <stdio.h>
#include <string.h>
#define MAX_N 50
#define MAX_ID_LEN 10
typedef struct {
char id[MAX_ID_LEN + 1];
float score;
} Student;
void swap(Student *a, Student *b) {
Student temp = *a;
*a = *b;
*b = temp;
}
int main() {
int n;
Student students[MAX_N];
printf("请输入学生人数 n:");
scanf("%d", &n);
printf("请输入每个学生的学号和成绩:\n");
for (int i = 0; i < n; i++) {
printf("学生 %d:", i + 1);
scanf("%s%f", students[i].id, &students[i].score);
}
// 冒泡排序
for (int i = 0; i < n - 1; i++) {
for (int j = 0; j < n - i - 1; j++) {
if (students[j].score < students[j + 1].score) {
swap(&students[j], &students[j + 1]);
}
}
}
printf("按成绩从高到低排序后的学生信息:\n");
for (int i = 0; i < n; i++) {
printf("学生 %d:\t%s\t%.1f\n", i + 1, students[i].id, students[i].score);
}
return 0;
}
```
程序中使用了一个结构体 `Student`,包括学生的学号和成绩两个字段。在主函数中,首先读入学生人数 `n`,然后依次读入每个学生的学号和成绩。接着使用冒泡排序算法按成绩从高到低排序学生信息。最后输出排序后的学生信息。
需要注意的是,学号使用了字符数组来存储,因此在读入学号时需要使用 `%s` 格式化字符串。同时,为了防止学号过长导致溢出,我们限制了学号长度不超过 10 位。
阅读全文