假设学生的基本信息包括学号、姓名、三门课程成绩以及个人平均成绩,定义一个能够表示学生信息的结构类型。输入n(1<=n<=10)个学生的成绩信息,计算并输出平均分最高的学生信息,平均分保留两位小数。如果平均分最高的学生有多个,按输入顺序输出第一个学生的信息。
输入格式:
输入整数n(1<=n<=10),在下面n行输入n个学生的信息,包括学号、姓名、三门课程成绩(整数)。
输出格式:
在一行中输出平均分最高的学生信息:学号、姓名、平均分(保留两位小数)。
输入样例:
3
101 Zhang 78 87 85
102 Wang 91 88 90
103 Li 75 90 84
输出样例:
num:102,name:Wang,average:89.67
解析:果然做了一道恶心的题之后,看什么题都那么眉清目秀,如沐春风~
代码:
#include<stdio.h>
struct stu{
char xuehao[4];
char name[11];
int d1;
int d2;
int d3;
double ave;
}stu[1001];
int main()
{
int n,sum=0,max=0;
scanf("%d",&n);
for(int i=0;i<n;i++)
{
scanf("%s %s %d %d %d",&stu[i].xuehao,&stu[i].name,&stu[i].d1,&stu[i].d2,&stu[i].d3);
sum=sum+stu[i].d1+stu[i].d2+stu[i].d3;
stu[i].ave=sum/3.0;
sum=0;
}
for(int i=0;i<n;i++)
{
if(stu[i].ave>stu[max].ave)
{
max=i;
}
}
printf("num:%s,name:%s,average:%.2f",stu[max].xuehao,stu[max].name,stu[max].ave);
return 0;
}