zoukankan      html  css  js  c++  java
  • 交换座位

    换座位 - LeetCode (中国) https://leetcode-cn.com/problems/exchange-seats/description/

    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  |
    +---------+---------+ 
    SELECT * FROM (
    SELECT a.id,b.student FROM seat a LEFT JOIN seat b ON a.id=b.id-1 WHERE a.id MOD 2=1 AND a.id!=(SELECT MAX(id) FROM seat)
    UNION ALL
    SELECT * FROM seat WHERE id MOD 2=1 AND id=(SELECT MAX(id) FROM seat)
    UNION ALL
    SELECT a.id,b.student FROM seat a LEFT JOIN seat b ON a.id=b.id+1 WHERE a.id MOD 2=0
    ) AS t
    ORDER BY id ASC;
    

      

  • 相关阅读:
    声音走样
    Terrain
    输出循环小数
    解决代码中多余的空行
    与二进制有关的几道面试题
    反转一个整数
    DirectX常见编译错误及解决办法
    STLset
    Visual Studio Autoexpand Information for DirectX 9
    素数环谈代码优化
  • 原文地址:https://www.cnblogs.com/rsapaper/p/9091250.html
Copyright © 2011-2022 走看看