【洛谷 P8717】[蓝桥杯 2020 省 AB2] 成绩分析 题解(线性扫描+打擂台法)

[蓝桥杯 2020 省 AB2] 成绩分析

题目描述

小蓝给学生们组织了一场考试,卷面总分为 100 100 100 分,每个学生的得分都是一个 0 0 0 到 100 100 100 的整数。

请计算这次考试的最高分、最低分和平均分。

输入格式

输入的第一行包含一个整数 n n n,表示考试人数。

接下来 n n n 行,每行包含一个 0 0 0 至 100 100 100 的整数,表示一个学生的得分。

输出格式

输出三行。

第一行包含一个整数,表示最高分。

第二行包含一个整数,表示最低分。

第三行包含一个实数,四舍五入保留正好两位小数,表示平均分。

样例 #1

样例输入 #1

复制代码
7
80
92
56
74
88
99
10

样例输出 #1

复制代码
99
10
71.29

提示

对于 50 % 50 \% 50% 的评测用例, 1 ≤ n ≤ 100 1 \leq n \leq 100 1≤n≤100。

对于所有评测用例, 1 ≤ n ≤ 10000 1 \leq n \leq 10000 1≤n≤10000。

蓝桥杯 2020 第二轮省赛 A 组 F 题(B 组 F 题)。


思路

首先,通过scanf函数读取考试人数n。

接下来,进入一个循环,循环次数为n。在每次循环中,执行以下操作:

读取一个学生的得分t,然后将这个得分加入到总分sum中。同时,如果这个得分比当前的最低分mini还要低,就更新最低分mini;如果这个得分比当前的最高分maxi还要高,就更新最高分maxi。

循环结束后,计算平均分avg,即总分sum除以人数n。

最后,通过printf函数输出最高分maxi、最低分mini和平均分avg。

注意

在求平均值时,要先将 sum 转换成 double 类型。


AC代码

cpp 复制代码
#include <algorithm>
#include <iostream>
#define AUTHOR "HEX9CF"
using namespace std;
using ll = long long;

const int INF = 0x3f3f3f3f;

int n;
int mini = INF;
int maxi = 0;
ll sum = 0;

int main() {
	scanf("%d", &n);
	for (int i = 1; i <= n; i++) {
		int t;
		scanf("%d", &t);
		sum += t;
		mini = min(mini, t);
		maxi = max(maxi, t);
	}

	double avg = (double)sum / n;
	printf("%d\n%d\n%.2lf\n", maxi, mini, avg);
	return 0;
}
相关推荐
代码程序猿RIP4 小时前
【C 语言面试】高频考点深度解析
java·面试·职场和发展
Croa-vo5 小时前
特斯拉 Tesla 面试经验分享|流程全解析 + 技术细节 + 面试感受
经验分享·面试·职场和发展
程序员三藏14 小时前
快速弄懂POM设计模式
自动化测试·软件测试·python·selenium·测试工具·设计模式·职场和发展
爱学测试的雨果19 小时前
14:00面试,14:06就出来了,问的问题过于变态了。。。
面试·职场和发展
程序员三藏19 小时前
使用Docker和Selenium构建自动化测试环境
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
落笔映浮华丶20 小时前
蓝桥杯零基础到获奖-第4章 C++ 变量和常量
java·c++·蓝桥杯
PPT百科21 小时前
PPT图标大小怎么调才协调?与文字的比例是多少 ?
经验分享·职场和发展·powerpoint·职场·ppt
铭哥的编程日记1 天前
深入浅出蓝桥杯:算法基础概念与实战应用(一)基础算法(上)
算法·职场和发展·蓝桥杯
小年糕是糕手1 天前
【数据结构】常见的排序算法 -- 选择排序
linux·数据结构·c++·算法·leetcode·蓝桥杯·排序算法
小安同学iter1 天前
SQL50+Hot100系列(11.9)
算法·leetcode·职场和发展