有10个学生,每个学生的数据包括学号、姓名、3门课程的成绩。读入这10个学生的数据,要求输出3门课程的总平均成绩,以及个人平均分最高的学生的数据

题目描述

有10个学生,每个学生的数据包括学号、姓名、3门课程的成绩。读入这10个学生的数据,要求输出3门课程的总平均成绩,以及个人平均分最高的学生的数据(包括学号、姓名、3门课程成绩、平均分数)。

输入

共有10行,每行包含了一个学生的学号(整数)、名字(长度不超过19的无空格字符串)和3门课程的成绩(0至100之间的整数),用空格隔开。

输出

第一行包含了3个实数,分别表示3门课程的总平均成绩,保留2位小数,每个数之后输出一个空格。
第二行输出个人平均分最高的学生的数据,与输入数据格式相同。如果有多位个人平均分最高的学生,输出按照输入顺序第一个最高分的学生数据。
请注意行尾输出换行。

样例输入

101 AAA 80 81 82
102 BBB 83 84 85
103 CCC 86 87 88
104 DDD 89 90 91
105 EEE 92 93 94
106 FFF 80 90 100
107 GGG 85 90 95
108 HHH 80 85 90
109 III 90 91 92
110 JJJ 91 88 87

样例输出

85.60 87.90 90.40 
105 EEE 92 93 94

 

#include<stdio.h>

struct Student{
	int num;
	char name[20];
	int score[3];
}stu[10];

void score_ave(struct Student s[]);
void person_ave(struct Student s[]);
int main() {
	int n=10;
	for (int i=0; i
  • 4
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对您的问题,以下是代码实现: ```python # 读入十个学生数据 students = [] for i in range(10): student = {} student['学号'] = input('请输入学号:') student['姓名'] = input('请输入姓名:') student['成绩1'] = float(input('请输入第一课程成绩:')) student['成绩2'] = float(input('请输入第二课程成绩:')) student['成绩3'] = float(input('请输入第三课程成绩:')) students.append(student) # 计算三课程平均成绩 average_scores = {'成绩1': 0, '成绩2': 0, '成绩3': 0} for student in students: average_scores['成绩1'] += student['成绩1'] average_scores['成绩2'] += student['成绩2'] average_scores['成绩3'] += student['成绩3'] average_scores['成绩1'] /= 10 average_scores['成绩2'] /= 10 average_scores['成绩3'] /= 10 print('三课程平均成绩分别为:成绩1:{:.2f},成绩2:{:.2f},成绩3:{:.2f}'.format(average_scores['成绩1'], average_scores['成绩2'], average_scores['成绩3'])) # 找出个人平均分最高学生数据 max_average_score = 0 max_average_score_student = {} for student in students: average_score = (student['成绩1'] + student['成绩2'] + student['成绩3']) / 3 if average_score > max_average_score: max_average_score = average_score max_average_score_student = student print('个人平均分最高学生数据为:学号:{},姓名:{},成绩1:{:.2f},成绩2:{:.2f},成绩3:{:.2f}'.format(max_average_score_student['学号'], max_average_score_student['姓名'], max_average_score_student['成绩1'], max_average_score_student['成绩2'], max_average_score_student['成绩3'])) ``` 注意,这里使用了一个字典来存储每个学生数据,其中键为学号姓名成绩1、成绩2、成绩3。同时,为了方便计算平均分,我们使用了一个字典来存储三课程成绩,最后再除以10得到平均分。而对于找出个人平均分最高学生数据,则需要遍历所有学生,计算每个学生平均分,并与当前最高平均分进行比较,找出最高分对应的学生即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值