SQL167 SQL类别高难度试卷得分的截断平均值
描述
牛客的运营同学想要查看大家在SQL类别中高难度试卷的得分情况。
请你帮她从exam_record数据表中计算所有用户完成SQL类别高难度试卷得分的截断平均值(去掉一个最大值和一个最小值后的平均值)。
示例数据:examination_info(exam_id试卷ID, tag试卷类别, difficulty试卷难度, duration考试时长, release_time发布时间)
id | exam_id | tag | difficulty | duration | release_time |
1 | 9001 | SQL | hard | 60 | 2020-01-01 10:00:00 |
2 | 9002 | 算法 | medium | 80 | 2020-08-02 10:00:00 |
示例数据:exam_record(uid用户ID, exam_id试卷ID, start_time开始作答时间, submit_time交卷时间, score得分)
id | uid | exam_id | start_time | submit_time | score |
1 | 1001 | 9001 | 2020-01-02 09:01:01 | 2020-01-02 09:21:01 | 80 |
2 | 1001 | 9001 | 2021-05-02 10:01:01 | 2021-05-02 10:30:01 | 81 |
3 | 1001 | 9001 | 2021-06-02 19:01:01 | 2021-06-02 19:31:01 | 84 |
4 | 1001 | 9002 | 2021-09-05 19:01:01 | 2021-09-05 19:40:01 | 89 |
5 | 1001 | 9001 | 2021-09-02 12:01:01 | (NULL) | (NULL) |
6 | 1001 | 9002 | 2021-09-01 12:01:01 | (NULL) | (NULL) |
7 | 1002 | 9002 | 2021-02-02 19:01:01 | 2021-02-02 19:30:01 | 87 |
8 | 1002 | 9001 | 2021-05-05 18:01:01 | 2021-05-05 18:59:02 | 90 |
9 | 1003 | 9001 | 2021-09-07 12:01:01 | 2021-09-07 10:31:01 | 50 |
10 | 1004 | 9001 | 2021-09-06 10:01:01 | (NULL) | (NULL) |
根据输入你的查询结果如下:
tag | difficulty | clip_avg_score |
SQL | hard | 81.7 |
从examination_info表可知,试卷9001为高难度SQL试卷,该试卷被作答的得分有[80,81,84,90,50],去除最高分和最低分后为[80,81,84],平均分为81.6666667,保留一位小数后为81.7
输入描述:
输入数据中至少有3个有效分数
select ei.tag,ei.difficulty,round((sum(score)-max(score)-min(score))/(count(*)-2),1) as clip_avg_score
from examination_info ei
join exam_record er on er.exam_id=ei.exam_id
where ei.tag='SQL' and ei.difficulty='hard' and er.score is not null
核心计算 - 去极值平均分
ROUND((SUM(score) - MAX(score) - MIN(score)) / (COUNT(*) - 2), 1) AS clip_avg_score
这个公式的作用是:去掉最高分和最低分后的平均分
公式拆解:
部分 | 作用 |
---|---|
SUM(score) | 所有分数的总和 |
MAX(score) | 最高分 |
MIN(score) | 最低分 |
SUM - MAX - MIN | 去掉最高分和最低分后的总分 |
COUNT(*) | 总人数 |
COUNT(*) - 2 | 去掉两人后的有效人数 |
总分÷人数 | 计算平均分 |
ROUND(..., 1) | 保留1位小数 |
💡 生活比喻:就像评委打分时去掉一个最高分和一个最低分