婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > SQL實(shí)現(xiàn)LeetCode(178.分?jǐn)?shù)排行)

SQL實(shí)現(xiàn)LeetCode(178.分?jǐn)?shù)排行)

熱門(mén)標(biāo)簽:拉卡拉外呼系統(tǒng) 大眾點(diǎn)評(píng)星級(jí)酒店地圖標(biāo)注 智能外呼系統(tǒng)復(fù)位 話(huà)務(wù)外呼系統(tǒng)怎么樣 高清地圖標(biāo)注道路 臨清電話(huà)機(jī)器人 外東北地圖標(biāo)注 云南電商智能外呼系統(tǒng)價(jià)格 400電話(huà)可以辦理嗎

[LeetCode] 178.Rank Scores 分?jǐn)?shù)排行

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    |
+-------+------+

這道題給了我們一個(gè)分?jǐn)?shù)表,讓我們給分?jǐn)?shù)排序,要求是相同的分?jǐn)?shù)在相同的名次,下一個(gè)分?jǐn)?shù)在相連的下一個(gè)名次,中間不能有空缺數(shù)字,這道題我是完全照著史蒂芬大神的帖子來(lái)寫(xiě)的,膜拜大神中...大神總結(jié)了四種方法,那么我們一個(gè)一個(gè)的來(lái)膜拜學(xué)習(xí),首先看第一種解法,解題的思路是對(duì)于每一個(gè)分?jǐn)?shù),找出表中有多少個(gè)大于或等于該分?jǐn)?shù)的不同的分?jǐn)?shù),然后按降序排列即可,參見(jiàn)代碼如下:

解法一:

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

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

解法二:

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

下面這種解法使用了內(nèi)交,Join是Inner Join的簡(jiǎn)寫(xiě)形式,自己和自己內(nèi)交,條件是右表的分?jǐn)?shù)大于等于左表,然后群組起來(lái)根據(jù)分?jǐn)?shù)的降序排列,十分巧妙的解法:

解法三:

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;

下面這種解法跟上面三種的畫(huà)風(fēng)就不太一樣了,這里用了兩個(gè)變量,變量使用時(shí)其前面需要加@,這里的:= 是賦值的意思,如果前面有Set關(guān)鍵字,則可以直接用=號(hào)來(lái)賦值,如果沒(méi)有,則必須要使用:=來(lái)賦值,兩個(gè)變量rank和pre,其中rank表示當(dāng)前的排名,pre表示之前的分?jǐn)?shù),下面代碼中的>表示不等于,如果左右兩邊不相等,則返回true或1,若相等,則返回false或0。初始化rank為0,pre為-1,然后按降序排列分?jǐn)?shù),對(duì)于分?jǐn)?shù)4來(lái)說(shuō),pre賦為4,和之前的pre值-1不同,所以rank要加1,那么分?jǐn)?shù)4的rank就為1,下面一個(gè)分?jǐn)?shù)還是4,那么pre賦值為4和之前的4相同,所以rank要加0,所以這個(gè)分?jǐn)?shù)4的rank也是1,以此類(lèi)推就可以計(jì)算出所有分?jǐn)?shù)的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

到此這篇關(guān)于SQL實(shí)現(xiàn)LeetCode(178.分?jǐn)?shù)排行)的文章就介紹到這了,更多相關(guān)SQL實(shí)現(xiàn)分?jǐn)?shù)排行內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

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

標(biāo)簽:無(wú)錫 揚(yáng)州 福州 溫州 三明 定西 阿里 山西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL實(shí)現(xiàn)LeetCode(178.分?jǐn)?shù)排行)》,本文關(guān)鍵詞  SQL,實(shí)現(xiàn),LeetCode,178.,分?jǐn)?shù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL實(shí)現(xiàn)LeetCode(178.分?jǐn)?shù)排行)》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于SQL實(shí)現(xiàn)LeetCode(178.分?jǐn)?shù)排行)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 榆中县| 临漳县| 蒲江县| 台江县| 辉南县| 石首市| 娱乐| 稷山县| 无极县| 孟津县| 明光市| 吴江市| 襄樊市| 老河口市| 芒康县| 安陆市| 乐山市| 德庆县| 东乡族自治县| 阿鲁科尔沁旗| 潮州市| 郎溪县| 洞头县| 镇雄县| 沽源县| 勐海县| 万安县| 阿尔山市| 巍山| 丰原市| 六枝特区| 炎陵县| 乌恰县| 吉隆县| 安龙县| 寻甸| 仁怀市| 饶阳县| 筠连县| 仪陇县| 永泰县|