题目:有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;
}