Medium之626.换座位
问题
小美是一所中学的信息科技老师,她有一张 seat 座位表,平时用来储存学生名字和与他们相对应的座位 id。
其中纵列的 id 是连续递增的
小美想改变相邻俩学生的座位。
你能不能帮她写一个 SQL query 来输出小美想要的结果呢?
示例:
id | student |
---|---|
1 | Abbot |
2 | Doris |
3 | Emerson |
4 | Green |
5 | Jeames |
结果
id | student |
---|---|
1 | Doris |
2 | Abbot |
3 | Green |
4 | Emerson |
5 | Jeames |
注意:
如果学生人数是奇数,则不需要改变最后一个同学的座位。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/exchange-seats
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解答
法一:CASE WHEN
select
(case when mod(id,2)=1 and counts!=id then id+1
when mod(id,2)=1 and counts= id then id
else id-1
end) as id,
student
from seat,
(select count(*) as counts
from seat) seat_counts
order by id
法二:if语句
select
if(id%2=0,
id-1,
if(id=(select count(*) from seat),
id,id+1)) as id,
student
from seat
order by id
解题思路
对于所有座位 id 是奇数的学生,修改其 id 为 id+1,如果最后一个座位 id 也是奇数,则最后一个座位 id 不修改。对于所有座位 id 是偶数的学生,修改其 id 为 id-1。
其中,最后一个座位id等价于座位总数量值。
还没有评论,来说两句吧...