欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > SQL面试题练习 —— 奖金瓜分问题

SQL面试题练习 —— 奖金瓜分问题

2024/11/30 14:47:28 来源:https://blog.csdn.net/hu_wei123/article/details/141024346  浏览:    关键词:SQL面试题练习 —— 奖金瓜分问题

目录

  • 1 题目
  • 2 建表语句
  • 3 题解

1 题目


在活动大促中,有玩游戏瓜分奖金环节。现有奖金池为 10000元,代表奖金池中的初始额度。用户的分数信息如下表。表中的数据代表每一个用户和其对应的得分,user_id 和 score 都不会有重复值。瓜分奖金的规则如下:按照 score 从高到低依次瓜分,每个人都能分走当前奖金池里面剩余奖金的一半,当奖金池里面剩余的奖金少于 250 时(不含),则停止瓜分奖金。现在需要查询出所有分到奖金的 user_id 和其对应的奖金。

样例数据

在这里插入图片描述

2 建表语句


--建表语句
create table if not exists t15_user_score
(user_id string,score   bigint
);--插入数据insert into t15_user_score(user_id, score)
values
('100',60),
('101',50),
('102',45),
('103',35),
('104',30),
('105',25),
('106',15),
('107',10)
本文同步在

3 题解


  1. 计算排名
selectuser_id,score,row_number() over(order by score desc) as rn
from t15_user_score;

执行结果

在这里插入图片描述

  1. 瓜分奖金

每个人得到当前奖池的 1 / 2 1/2 1/2,排名 rn 的得到的为 1 / 2 r n ∗ 10000 1/2^{rn} *10000 1/2rn10000,奖池剩余的也是 1 / 2 r n ∗ 10000 1/2^{rn} *10000 1/2rn10000。如果无限瓜分下去,看下是什么结果。

select user_id,score,power(0.5, rn) * 10000 as prize
from (select user_id,score,row_number() over (order by score desc) as rnfrom t15_user_score) t

执行结果

在这里插入图片描述

  1. 限制瓜分条件,得到最终结果

题目中要求:当奖金池里面剩余的奖金少于 250 时(不含),则停止瓜分奖金。我们可以看到104瓜分之后奖池剩余312.5应该继续瓜分,105瓜分完成之后才会停止。

select user_id,score,power(0.5, rn) * 10000 as prize
from (select user_id,score,row_number() over (order by score desc) as rnfrom t15_user_score) t
where power(0.5, rn - 1) * 10000 >=250

执行结果

在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com