好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > SQL實現LeetCode(178.分數排行)

SQL實現LeetCode(178.分數排行)

熱門標簽:拉卡拉外呼系統 大眾點評星級酒店地圖標注 智能外呼系統復位 話務外呼系統怎么樣 高清地圖標注道路 臨清電話機器人 外東北地圖標注 云南電商智能外呼系統價格 400電話可以辦理嗎

[LeetCode] 178.Rank Scores 分數排行

Write a SQL query to rank scores. If there is a tie between two scores, both should have the same ranking. Note that after a tie, the next ranking number should be the next consecutive integer value. In other words, there should be no "holes" between ranks.

+----+-------+
| Id | Score |
+----+-------+
| 1  | 3.50  |
| 2  | 3.65  |
| 3  | 4.00  |
| 4  | 3.85  |
| 5  | 4.00  |
| 6  | 3.65  |
+----+-------+

For example, given the above Scores table, your query should generate the following report (order by highest score):

+-------+------+
| Score | Rank |
+-------+------+
| 4.00  | 1    |
| 4.00  | 1    |
| 3.85  | 2    |
| 3.65  | 3    |
| 3.65  | 3    |
| 3.50  | 4    |
+-------+------+

這道題給了我們一個分數表,讓我們給分數排序,要求是相同的分數在相同的名次,下一個分數在相連的下一個名次,中間不能有空缺數字,這道題我是完全照著史蒂芬大神的帖子來寫的,膜拜大神中...大神總結了四種方法,那么我們一個一個的來膜拜學習,首先看第一種解法,解題的思路是對于每一個分數,找出表中有多少個大于或等于該分數的不同的分數,然后按降序排列即可,參見代碼如下:

解法一:

SELECT Score, 
(SELECT COUNT(DISTINCT Score) FROM Scores WHERE Score >= s.Score) Rank 
FROM Scores s ORDER BY Score DESC;

跟上面的解法思想相同,就是寫法上略有不同:

解法二:

SELECT Score,
(SELECT COUNT(*) FROM (SELECT DISTINCT Score s FROM Scores) t WHERE s >= Score) Rank
FROM Scores ORDER BY Score DESC;

下面這種解法使用了內交,Join是Inner Join的簡寫形式,自己和自己內交,條件是右表的分數大于等于左表,然后群組起來根據分數的降序排列,十分巧妙的解法:

解法三:

SELECT s.Score, COUNT(DISTINCT t.Score) Rank
FROM Scores s JOIN Scores t ON s.Score = t.Score
GROUP BY s.Id ORDER BY s.Score DESC;

下面這種解法跟上面三種的畫風就不太一樣了,這里用了兩個變量,變量使用時其前面需要加@,這里的:= 是賦值的意思,如果前面有Set關鍵字,則可以直接用=號來賦值,如果沒有,則必須要使用:=來賦值,兩個變量rank和pre,其中rank表示當前的排名,pre表示之前的分數,下面代碼中的>表示不等于,如果左右兩邊不相等,則返回true或1,若相等,則返回false或0。初始化rank為0,pre為-1,然后按降序排列分數,對于分數4來說,pre賦為4,和之前的pre值-1不同,所以rank要加1,那么分數4的rank就為1,下面一個分數還是4,那么pre賦值為4和之前的4相同,所以rank要加0,所以這個分數4的rank也是1,以此類推就可以計算出所有分數的rank了。

解法四:

SELECT Score,
@rank := @rank + (@pre > (@pre := Score)) Rank
FROM Scores, (SELECT @rank := 0, @pre := -1) INIT 
ORDER BY Score DESC;

參考資料:

https://leetcode.com/discuss/40116/simple-short-fast

到此這篇關于SQL實現LeetCode(178.分數排行)的文章就介紹到這了,更多相關SQL實現分數排行內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • SQL實現LeetCode(184.系里最高薪水)
  • SQL實現LeetCode(183.從未下單訂購的顧客)
  • SQL實現LeetCode(182.重復的郵箱)
  • SQL實現LeetCode(181.員工掙得比經理多)
  • SQL實現LeetCode(180.連續的數字)
  • SQL實現LeetCode(177.第N高薪水)
  • SQL實現LeetCode(176.第二高薪水)
  • SQL實現LeetCode(185.系里前三高薪水)

標簽:無錫 揚州 福州 溫州 三明 定西 阿里 山西

巨人網絡通訊聲明:本文標題《SQL實現LeetCode(178.分數排行)》,本文關鍵詞  SQL,實現,LeetCode,178.,分數,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL實現LeetCode(178.分數排行)》相關的同類信息!
  • 本頁收集關于SQL實現LeetCode(178.分數排行)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 男人的天堂一区二区视频在线观看 | 美女自己扒开内??结男生看个够 | 夜爽爽| 一级毛片在线播放免费| 少妇搡BBBB搡BBB搡爱恋| 亚洲美女综合网| freehdxxxxvideo| 吻胸摸全身视频| 漂亮人妻被维修工侵犯的后果| 加勒比美痴女北岛玲播放| cjod-261波多野结衣| 亚洲熟妇AV乱码在线观看| 国产美女一级A片免费| 青青青久在线视频免费观看| 色情乱婬一区二区三区在线播放| 啊哈哈哈哈主人我错了哈哈哈哈柯| 女人把腿伸开让男人桶肌肌| 欧美精品亚洲精品日韩专区一| 身体改造媚药调教催眠小说| 缅甸KK区女人糟蹋原视频| 国内免费无码一级毛片| 男女激烈嘿咻嘿咻动态图试看| 成人国产精品视频| ?77788色婬免费网站视频 | 欧美特级生活片| 母子乱轮视频| 国产精品免费一区二区三区视频 | 日本特级黄大片| 看特级大黄一片| 农村美女沟厕嘘嘘被偷看| 色翁荡熄邢爱爱全文阅读| 男人的??伸到??里| 边摸边吃奶边做爽视频免费| 南投市| 欧美边做饭边被躁bd在线看| 一本大道在线一本久道| 久夜tv| 无码动漫一区二区三区在线观看| 熟女???码免费播放www| 台湾a级艳片寡妇的男人| 亚洲操操操|