代码如下
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
/*
1.练习结构体数组排序
从键盘输入5个学生的信息(姓名、学号、成绩),
存入一个结构体数组中,计算平均分,并按成绩
高低排序并输出.
*/
#define N 5
typedef struct student
{
char *name;
int id;
int grade;
}STU;
//按成绩对每个学生进行排序
void compare(STU *arr,int n)
{
int i , j= 0;
STU temp ;
memset(&temp, 0, sizeof(temp));
for ( i = 0; i < n-1; i++)
{
for (j = 0; j < n-i-1; j++)//此处借用ai
{
if (arr[j].grade < arr[j+1].grade)
{
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
return;
}
//结构体存在堆区,指针指向堆区
int main(int argc, char const *argv[])
{
STU *stu = (STU*)malloc(N*sizeof(STU));
memset(stu, 0, N*sizeof(stu));//结构体初始化
int i,sum = 0;
printf("Please input 5 students' info: \n");
for ( i = 0; i < N; i++)
{
// 在内存空间中设置name的单独内存
stu[i].name = (char*)malloc(32*sizeof(char));
scanf("%s %d %d", stu[i].name, &stu[i].id, &stu[i].grade);
}
compare(stu,N);
for ( i = 0; i < N; i++)
{
sum += stu[i].grade;
}
printf("平均分:%f\n",(float)sum/N);
printf("按成绩高低排序后:\n");
for ( i = 0; i < N; i++)
{
printf("%s %d %d\n", stu[i].name, stu[i].id, stu[i].grade);
}
for ( i = 0; i < N; i++)
{
free(stu[i].name);
stu[i].name = NULL;
}
return 0;
}
运行结果如下