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

目录

  • [1 题目](#1 题目)
  • [2 建表语句](#2 建表语句)
  • [3 题解](#3 题解)

1 题目

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

样例数据

2 建表语句

sql 复制代码
--建表语句
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. 计算排名
sql 复制代码
select
    user_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/2rn∗10000,奖池剩余的也是 1 / 2 r n ∗ 10000 1/2^{rn} *10000 1/2rn∗10000。如果无限瓜分下去,看下是什么结果。

sql 复制代码
select user_id,
       score,
       power(0.5, rn) * 10000 as prize
from (select user_id,
             score,
             row_number() over (order by score desc) as rn
      from t15_user_score) t

执行结果

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

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

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

执行结果

相关推荐
AIHE-TECH3 分钟前
多台西门子PLC控制器与SQL数据库对接(带边缘计算)的案例
数据库·sql·mysql·边缘计算·达梦数据库·西门子plc·智能网关
思成不止于此12 分钟前
【MySQL 零基础入门】MySQL 函数精讲(二):日期函数与流程控制函数篇
android·数据库·笔记·sql·学习·mysql
uhakadotcom33 分钟前
Python Protobuf 全面教程:常用 API 串联与实战指南
前端·面试·github
shoa_top1 小时前
一文带你掌握 JSONP:从 Script 标签到手写实现
前端·面试
知其然亦知其所以然1 小时前
小米的奇幻编程之旅:当 JavaScript 语法变成了一座魔法城
前端·javascript·面试
Aniugel2 小时前
Vue2怎么搭建前端性能/错误/行为监控体系
vue.js·面试·监控
a程序小傲2 小时前
京东Java面试被问:ZGC的染色指针如何实现?内存屏障如何处理?
java·后端·python·面试
木风小助理3 小时前
子查询与 JOIN 查询性能比较:执行机制与适用场景解析
数据库·sql·mysql
程序员清风3 小时前
别卷模型了!上下文工程才是大模型应用的王道!
java·后端·面试
while(1){yan}4 小时前
JAVA中如何操作文件
java·开发语言·面试