lithium


私信TA

用户名:uq_57590927925

访问量:111

签 名:

等  级
排  名 7121
经  验 1345
参赛次数 0
文章发表 3
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

解题思路:

注意事项:

参考代码:

#include<stdio.h>

typedef struct Student {

    char num[20];

    char name[10];

    double score[3];

}STU;

void Average(STU* stu, int n);

void Highest_score(STU* stu, int n);

int main()

{

    STU stu[100] = { 0 };

    int n = 0;

    scanf("%d", &n);

    for (int i = 0; i < n; i++)

    {

        scanf("%s%s%lf%lf%lf", &stu[i].num, &stu[i].name, &stu[i].score[0], &stu[i].score[1], &stu[i].score[2]);

    }

    Average(stu, n);

    Highest_score(stu, n);

    return 0;

}

void Average(STU* stu, int n)

{

    double average[3] = { 0 };

    int i = 0;

    for (i = 0; i < 3; i++)

    {

        for(int j=0;j<n;j++)

        {

            average[i]+=stu[j].score[i];

        }

        average[i]/=n;

    }

    for (i = 0; i < 3; i++)

    {

        printf("%.0lf ", average[i]);

    }

    printf("\n");

}

void Highest_score(STU* stu, int n)

{

    int sum[100] = { 0 };

    int i = 0;

    for (i = 0; i < n; i++)

    {

        sum[i] = stu[i].score[0] + stu[i].score[1] + stu[i].score[2];

    }

    int a = sum[0], b = 0;

    for (i = 0; i < n; i++)

    {

        if (a <= sum[i])

        {

            a = sum[i];

            b = i;

        }

    }

    printf("%s %s %.0lf %.0lf %.0lf", stu[b].num, stu[b].name, stu[b].score[0], stu[b].score[1], stu[b].score[2]);

}


 

0.0分

0 人评分

  评论区

  • «
  • »