Medium之1204.最后一个能进入电梯的人

表: Queue

Column NameType
person_idint
person_namevarchar
weightint
turnint

person_id 是这个表的主键。
该表展示了所有等待电梯的人的信息。
表中 person_id 和 turn 列将包含从 1 到 n 的所有数字,其中 n 是表中的行数。

问题

写一条 SQL 查询语句查找最后一个能进入电梯且不超过重量限制(电梯最大载重量为 1000。)的 person_name 。题目确保队列中第一位的人可以进入电梯 。

示例

Queue 表

person_idperson_nameweightturn
5George Washington2501
3John Adams3502
6Thomas Jefferson4003
2Will Johnliams2004
4Thomas Jefferson1755
1James Elephant5006

Result 表

person_name
Thomas Jefferson

为了简化,Queue 表按 turn 列由小到大排序。
上例中 George Washington(id 5), John Adams(id 3) 和 Thomas Jefferson(id 6) 将可以进入电梯,因为他们的体重和为 250 + 350 + 400 = 1000。
Thomas Jefferson(id 6) 是最后一个体重合适并进入电梯的人。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/last-person-to-fit-in-the-bus
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解答

法一:自联结
关键性思路

通过自联结,根据where a.turn >= b.turn
group by a.person_id 实现累加求和

select a.person_name
from queue a,queue b
where a.turn >= b.turn 
group by a.person_id
having sum(b.weight)<=1000
order by a.turn desc
limit 1
法二:窗口函数
关键性思路

over(order by turn):turn=1的窗口只有所在行,turn=2的窗口有1,2所在行,以此类推,turn=6的窗口有前1,2,3,4,5,6行,再前面用sum(weight)窗口函数,实现累加求和。

select person_name
from (
    select *
        sum(weight) over(order by turn) as swt
    from queue) t
where swt <= 1000
order by turn desc 
limit 1
法三:自定义变量
关键性思路

将每一条记录的 weight 按照 turn 的顺序和自定义变量相加并生成新的记录。生成临时表并处理。

select person_name
from (
    select person_name,@pre:=@pre +weight as swt
    from queue,(select @pre:=0) t1
    order by turn
    ) t
where swt<=1000
order by t.swt desc
limit 1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值