学生成绩排序 (20 分)假设学生的基本信息包括学号、姓名、三门课程成绩以及个人平均成绩,定义一个能够表示学生信息的结构类型。输入n(n<50)个学生的成绩信息,按照学生的个人平均分从高到低输出他
作者:互联网
#include<stdio.h>
struct student{//定义一个结构体分别放入学号姓名,三个成员的分数
int num;
char name[10];
int s[3];
double ave;
};
int main()
{ struct student a[1000];//建议将空空间定义的大一些,以免造成空间储存不足
int n,i,j;
int sum=0;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d %s %d %d %d",&a[i].num,&a[i].name,&a[i].s[0],&a[i].s[1],&a[i].s[2]);
sum=a[i].s[0]+a[i].s[1]+a[i].s[2];//求和
a[i].ave=(sum*1.0)/3;//秋三个数的平均数
}
struct student t;//结构类型要一致
for(i=0;i<n-1;i++)
{
for(j=0;j<n-i-1;j++)
{
if(a[j].ave<a[j+1].ave)
{
t=a[j+1];
a[j+1]=a[j];
a[j]=t;
}
}
}
for(i=0;i<n;i++){
printf("%d,%s,%.2lf\n",a[i].num,a[i].name,a[i].ave);//分别输出学号,姓名,以及平均成绩
}
return 0;
}
标签:struct,int,信息,学生,num,student,ave,成绩,name 来源: https://blog.csdn.net/Det10528/article/details/120796547