设计一个结构体,可存储每个学生的姓名、三门课程成绩、以及平均成绩。试按如下要求编写计算平均成绩并排序输出的程序:
(1)主函数中由用户输入班级人数,并以动态内存申请方式建立结构数组,同时输入每个学生的姓名和三门课程的成绩,并计算平均成绩。
(2)排序的功能要封装成函数,函数参数包含结构数组。要求按平均成绩的降序进行排序。
(3)排序后每个学生的姓名和他的平均成绩(要求保留 1 位小数点)在主函数中输出。
#include<stdio.h>
struct studentT
{
char name[20];
int score[3];
double average;
};
void bubbleSort(struct studentT s[], int size)
{
int i, j, flag;
struct studentT tmp;
for (i = 1; i < size; ++i) {
flag = 0;
for (j = 0; j < size-i; ++j)
if (s[j].average < s[j+1].average) {
tmp = s[j];
s[j] = s[j+1];
s[j+1] = tmp;
flag = 1;
}
if (!flag) break;
}
}
int main( )
{
struct studentT *s;
int i, num;
printf("请输入学生人数:");
scanf("%d", &num);
s = (struct studentT *)calloc(num, sizeof(struct studentT));
for(i=0;i<num;i++){
printf("请输入第%d 个学生的姓名和三门课的成绩:",i+1);
scanf("%s%d%d%d", s[i].name, &s[i].score[0], &s[i].score[1],
&s[i].score[2]);
s[i].average = s[i].score[0] + s[i].score[1] + s[i].score[2];
}
bubbleSort(s, num);
printf("排序后的平均成绩:\n");
for(i=0;i<num;i++)
printf ("%s\t%.1f\n", s[i].name, s[i].average);
free(s);
return 0;
}