解题思路:

注意事项:

参考代码:

#include<stdio.h>
#include<malloc.h>
typedef struct student
{
char s_num[10];
char name[15];
int subject[3];
}stu;

int main()
{
int N,i = 0,j = 0 ,sum[3] = {0};                                   //在C语言中一般视大写的字母代表的是常量
scanf("%d", &N);
stu* p = (stu*)malloc(N * sizeof(stu));
for (i = 0; i < N;  i++)
scanf("%s%s%d%d%d", p[i].s_num, p[i].name, &p[i].subject[0], &p[i].subject[1], &p[i].subject[2]);
for (i = 0; i < N;  i++)                                         //通过for循环,实现了计总分,和最高分的查询
{
    sum[0]+=p[i].subject[0];                                    //续上:因为要找到最高的分数,因而必须要有循环,所以没有必要
    sum[1]+=p[i].subject[1];                                    //再设一个循环,在这个循环中就可以计算出总分和,最高分对应的j
    sum[2]+=p[i].subject[2];
        if((p[i].subject[0]+p[i].subject[1]+p[i].subject[2])>(p[j].subject[0]+p[j].subject[1]+p[j].subject[2]))
        {
              j = i;
        }
    }
    printf("%d %d %d\n",sum[0]/N,sum[1]/N,sum[2]/N);
    printf("%s %s %d %d %d", p[j].s_num, p[j].name, p[j].subject[0], p[j].subject[1], p[j].subject[2]);
}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论