解题思路:

1、使用结构体存放学生信息

2、成员 index ,用来区分每个学生

3、成员 score[4] 存放各科成绩和总成绩

4、输入人数不定,所以结构体大小由 malloc 动态分配

注意事项:

参考代码:

#include <stdio.h>
#include <malloc.h>

typedef struct _stu_info {
	int index;
	/*
	 * score[0] - score[2] 存储各科成绩
	 * score[3] 存储总成绩
	 * */
	int score[4];
	char name[32];
	char stuid[8];
}stuInfo;

/*
 * 获取最高分对应的下标
 * */
int get_tallest_score_index(stuInfo *p, int size)
{
	int i = 0, index = 0;
	for(i = 1; i < size; i++)
	{
		if( p[index].score[3] < p[i].score[3] )
		{
			index = i;
		}
	}
	return index;
}

int main(int argc, char **argv)
{
	int n = 0, sum[3] = {0}, i = 0, tallest = 0;
	scanf("%d", &n);
	if(n < 1)
	{
		return -1;
	}
	stuInfo *info = NULL;
	info = (stuInfo *)malloc(sizeof(stuInfo));
	if(info == NULL)
	{
		return -1;
	}
	for(i = 0; i < n; i++)
	{
		info[i].index = i;
		scanf("%s %s %d %d %d",
				info[i].stuid,
				info[i].name,
				&info[i].score[0],
				&info[i].score[1],
				&info[i].score[2]
				);
		/*计算个人总成绩*/
		info[i].score[3] = info[i].score[0] + info[i].score[1] + info[i].score[2];
		/*以下计算各科总分*/
		sum[0] = sum[0] + info[i].score[0];
		sum[1] = sum[1] + info[i].score[1];
		sum[2] = sum[2] + info[i].score[2];
	}
	/*输出各科平均分*/
	printf("%d %d %d\n", sum[0]/n, sum[1]/n, sum[2]/n);
	/*获取最高分下表*/
	tallest = get_tallest_score_index(info, n);
	/*输出最高分学生成绩*/
	printf("%s %s %d %d %d\n", 
			info[tallest].stuid,
			info[tallest].name,
			info[tallest].score[0],
			info[tallest].score[1],
			info[tallest].score[2]
			);
	return 0;
}


点赞(2)
 

0.0分

2 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论