【洛谷 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;
}
相关推荐
qq_459234429 天前
【题库】| 商用密码应用安全性评估从业人员考核题库(四十)
职场和发展·密码学·学习方法·考核·商用密码·商用密码应用安全性评估·密评
敲敲了个代码9 天前
[特殊字符] 空数组的迷惑行为:为什么 every 为真,some 为假?
前端·javascript·react.js·面试·职场和发展
诚思报告YH10 天前
视频面试软件市场洞察:2026 - 2032年复合年均增长率(CAGR)为10.3%
面试·职场和发展
重生之后端学习10 天前
74. 搜索二维矩阵
开发语言·数据结构·算法·职场和发展·深度优先
tyb33333310 天前
leetcode:吃苹果和队列
算法·leetcode·职场和发展
Pitiless-invader10 天前
MySQL 相关知识及面试问题汇总
面试·职场和发展
重生之后端学习10 天前
35. 搜索插入位置
java·数据结构·算法·leetcode·职场和发展·深度优先
逆境不可逃10 天前
【从零入门23种设计模式08】结构型之组合模式(含电商业务场景)
线性代数·算法·设计模式·职场和发展·矩阵·组合模式
筱昕~呀10 天前
冲刺蓝桥杯-DFS板块(第二天)
算法·蓝桥杯·深度优先
zheshiyangyang10 天前
前端面试基础知识整理【Day-10】
前端·面试·职场和发展