题解 | #对试卷得分做min-max归一化#
对试卷得分做min-max归一化
https://www.nowcoder.com/practice/2b7acdc7d1b9435bac377c1dcb3085d6
# 请你将用户作答高难度试卷的得分在每份试卷作答记录内执行min-max归一化后缩放到[0,100]区间,并输出用户ID、试卷ID、归一化后分数平均值;最后按照试卷ID升序、归一化分数降序输出。(注:得分区间默认为[0,100],如果某个试卷作答记录中只有一个得分,那么无需使用公式,归一化并缩放后分数仍为原分数)。
select
uid,
exam_id,
if(avg(max_s)=avg(min_s),round(avg(score),0),
round(avg(100*(score-min_s)/(max_s-min_s)), 0)
) as avg_new_score
from
(
select
uid,
exam_id,
score,
max(score) over(partition by exam_id) as max_s,
min(score) over(partition by exam_id) as min_s
from exam_record
where exam_id in(
select exam_id from examination_info where difficulty = 'hard'
) and score is not null
)t1
group by uid, exam_id
order by exam_id, avg_new_score desc
查看1道真题和解析