题目:有N个学生,每个学生的数据包括学号、姓名、3门课的成绩,从键盘输入N个学生的数据,要求打印出3门课的总平均成绩,以及最高分的学生的数据(包括学号、姓名、3门课成绩)
输入:学生数量N占一行每个学生的学号、姓名、三科成绩占一行,空格分开。
输出:各门课的平均成绩 最高分的学生的数据(包括学号、姓名、3门课成绩)
Exemple:
输入:2
1 blue 90 80 70
b clan 80 70 60
输出:85 75 65
1 blue 90 80 70
解题思路:这道题用到了我们所学的结构体,然后结构体中包含的有字符串类型的学号和姓名以及3门课程的成绩,然后题上说还要打印出最高分学生的数据,so我们还要定义一个学生的总分,通过比较学生的总分来判断哪个学生的分数最高。这道题我们还要注意的是我们已经知道了一共有3门课程,因此我们在计算课程的平均分时,只用把每一门的总分加起来除以N就行咧。 (类似于我们之前数组的冒泡排序,外循环循环一次然后最后一个数就是最大数)
My DaiMa:
#include<stdio.h>
struct person
{
char num[3],name[11];
int a,b,c,S;
};
int main()
{
int i,n,m,j;
struct person s[11],t;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%s %s",s[i].num,s[i].name);
scanf("%d%d%d",&s[i].a,&s[i].b,&s[i].c);
s[i].S=s[i].a+s[i].b+s[i].c; //这是求每个学生的3门课程的总成绩
}
m=0;
for(i=0;i<n;i++)
m=m+s[i].a;
printf("%.0lf ",(double)m/n); //这是求第1门课程的平均分
m=0;
for(i=0;i<n;i++)
m=m+s[i].b;
printf("%.0lf ",(double)m/n); //而介个咧就是求第2门课程的平均分
m=0;
for(i=0;i<n;i++)
m=m+s[i].c;
printf("%.0lf\n",(double)m/n); //辣么最后一个就是求第3门课程的平均分咧
for(i=1;i<2;i++) //这和我们之前学的数组冒泡排序是一样一样的,因为它要的是最高分的学生
{ 的数据,so我们的外层for循环只用循环一次就ok咧,即其最后一个就是最高分的学生
for(j=0;j<n-i;j++)
{
if(s[j].S>s[j+1].S) //这是通过比较每个学生的总成绩来进行排序
{
t=s[j];
s[j]=s[j+1];
s[j+1]=t;
}
}
}
printf("%s %s %d %d %d",s[n-1].num,s[n-1].name,s[n-1].a,s[n-1].b,s[n-1].c); //输出最后一个学生的数据就是最高分学生的数据
return 0;
}