LeetCode - 626. Exchange Seats

Posted 码上哈希

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode - 626. Exchange Seats相关的知识,希望对你有一定的参考价值。

Mary is a teacher in a middle school and she has a table seat storing students‘ names and their corresponding seat ids.

The column id is continuous increment.

 

Mary wants to change seats for the adjacent students.

 

Can you write a SQL query to output the result for Mary?

 

+---------+---------+
|    id   | student |
+---------+---------+
|    1    | Abbot   |
|    2    | Doris   |
|    3    | Emerson |
|    4    | Green   |
|    5    | Jeames  |
+---------+---------+

For the sample input, the output is:

 

+---------+---------+
|    id   | student |
+---------+---------+
|    1    | Doris   |
|    2    | Abbot   |
|    3    | Green   |
|    4    | Emerson |
|    5    | Jeames  |
+---------+---------+

Note:
If the number of students is odd, there is no need to change the last one‘s seat.

# Write your mysql query statement below
SELECT
    s.id,
    s.student
FROM
    (
        SELECT
            id - 1 AS id,
            student
        FROM
            seat
        WHERE
            (id % 2 = 0)
        UNION
            SELECT
                (CASE WHEN (cnt%2=1) AND id=cnt THEN id ELSE id + 1 END) AS id,
                student
            FROM
                seat,
                (select count(*) as cnt from seat) as seatcnt
            WHERE
                (id % 2 = 1)
    ) s
GROUP BY
    s.id ASC

 


以上是关于LeetCode - 626. Exchange Seats的主要内容,如果未能解决你的问题,请参考以下文章

Final Project - IA626

CF626C Block Towers

CodeForces - 626D

626

[CF626F]Group Projects

CF626F:Group Projects