解题思路:在成绩统计1 的基础上添加

注意事项:比较菜,不喜勿喷

参考代码:

#include<math.h>

#include<string.h>

#include<stdlib.h> 

#include <stdio.h>

struct shei

{

char name[20];

char num[20];

int yuwen;

int shuxue;

int yingyu;

};


void input(int i, struct shei haoduo[])

{

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

{

scanf("%s %s %d %d %d", &haoduo[ii].num, &haoduo[ii].name, &haoduo[ii].yuwen, &haoduo[ii].shuxue, &haoduo[ii].yingyu);

}

}


void print(int i, struct shei haoduo[])

{

int avgy=0, avgyi=0, avgs=0,da=0;

int hh[100] = { 0 };

for (int ii = 0; ii < i; ii++)                         //求出所有科目的平均成绩

{

avgy = avgy + haoduo[ii].yuwen;

avgyi = avgyi + haoduo[ii].shuxue;

avgs = avgs + haoduo[ii].yingyu;

}


printf("%d %d %d\n", avgy / i, avgyi / i, avgs/i);     //输出平均成绩


for (int ii = 0; ii < i; ii++)                         //求出所有人的总分

{

hh[ii] = haoduo[ii].yuwen + haoduo[ii].shuxue + haoduo[ii].yingyu;

}


for (int ii = 1; ii < i; ii++)                         //判断出总分最高的那个人

{

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

{

if (hh[ii1]>hh[ii])

{

hh[ii] = 0;

}

}

}


for (int ii = 1; ii < i; ii++)                         //判断出总分最高的那个人

{

if(hh[ii] != 0)

{

da = ii;

    }

}


printf("%s %s %d %d %d", haoduo[da].num, haoduo[da].name, haoduo[da].yuwen, haoduo[da].shuxue, haoduo[da].yingyu);

}


int main()

{

struct shei haoduo[100];

int i=0, j, k, l;

scanf("%d", &i);

input(i, haoduo);

print(i, haoduo);

    return 0;

}


点赞(0)
 

0.0分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论