结构体类型数组\n编程定义使用结构体stu类型数组,成员包括学号,姓名,c语言成绩,1.将10名学生的数据按成绩从高到低排序输出到屏幕上,学生信息排序编写函数实现。2.将学生中低于平均分的学生记录信息输
时间: 2023-04-25 07:05:43 浏览: 167
出到屏幕上,编写函数实现。
定义结构体类型数组:
```
typedef struct {
int id; // 学号
char name[20]; // 姓名
float score; // c语言成绩
} stu;
stu students[10]; // 定义10名学生的结构体数组
```
1. 将10名学生的数据按成绩从高到低排序输出到屏幕上,学生信息排序编写函数实现。
可以使用冒泡排序或快速排序等算法进行排序,以下是冒泡排序的实现:
```
void sort_by_score(stu students[], int n) {
int i, j;
stu temp;
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - i - 1; j++) {
if (students[j].score < students[j + 1].score) {
temp = students[j];
students[j] = students[j + 1];
students[j + 1] = temp;
}
}
}
}
// 调用函数进行排序
sort_by_score(students, 10);
// 输出排序后的学生信息
for (i = 0; i < 10; i++) {
printf("学号:%d,姓名:%s,成绩:%.2f\n", students[i].id, students[i].name, students[i].score);
}
```
2. 将学生中低于平均分的学生记录信息输出到屏幕上,编写函数实现。
可以先计算出平均分,然后遍历数组,将低于平均分的学生信息输出即可。
```
void print_below_average(stu students[], int n) {
int i;
float sum = 0, average;
for (i = 0; i < n; i++) {
sum += students[i].score;
}
average = sum / n;
printf("平均分为:%.2f\n", average);
printf("低于平均分的学生信息如下:\n");
for (i = 0; i < n; i++) {
if (students[i].score < average) {
printf("学号:%d,姓名:%s,成绩:%.2f\n", students[i].id, students[i].name, students[i].score);
}
}
}
// 调用函数输出低于平均分的学生信息
print_below_average(students, 10);
```
阅读全文