LeetCode の SQL 実装 (197. 気温上昇)

LeetCode の SQL 実装 (197. 気温上昇)

[LeetCode] 197.気温上昇

Weather テーブルが指定されている場合、前の日付 (昨日の日付) と比較して気温が高いすべての日付の ID を検索する SQL クエリを記述します。

+---------+------------+------------------+
| ID(INT) | 日付(DATE) | 温度(INT) |
+---------+------------+------------------+
| 1 | 2015-01-01 | 10 |
| 2 | 2015-01-02 | 25 |
| 3 | 2015-01-03 | 20 |
| 4 | 2015-01-04 | 30 |
+---------+------------+------------------+

たとえば、上記の Weather テーブルに対して次の ID を返します。

+----+
| ID |
+----+
| 2 |
| 4 |
+----+

この問題では、天気表が与えられ、前日よりも気温が高い ID を見つけるように求められます。ID は必ずしも順番に並べられているわけではないので、日付に基づいて前日を見つける必要があります。MySQL 関数 Datadiff を使用して、2 つの日付の差を計算できます。制約は、気温が高く、日付の差が 1 であることです。以下のコードを参照してください。

解決策1:

天気 w1、天気 w2 から w1.Id を選択
w1.Temperature > w2.Temperature かつ DATEDIFF(w1.Date, w2.Date) = 1;

次のソリューションでは、MySQL TO_DAYS 関数を使用して日付を日数に変換し、残りは上記と同じです。

解決策2:

天気 w1、天気 w2 から w1.Id を選択
w1.Temperature > w2.Temperature かつ TO_DAYS(w1.Date) = TO_DAYS(w2.Date) + 1 の場合;

以下のコードに示すように、Subdate 関数を使用して日付から 1 を減算することもできます。

解決策3:

天気 w1、天気 w2 から w1.Id を選択
w1.Temperature > w2.Temperature かつ SUBDATE(w1.Date, 1) = w2.Date;

最後に、まったく異なるソリューションが使用されます。2 つの変数 pre_t と pre_d は、それぞれ前回の気温と前回の日付を表すために使用されます。現在の気温は前回の気温よりも高く、日付の差は 1 である必要があります。上記の 2 つの条件が満たされている場合は、それが Id として選択され、そうでない場合は NULL になります。次に、pre_t と pre_d が現在の値に更新され、選択された Id は空ではありません。

解決策4:

SELECT ID FROM (
SELECT CASE WHEN Temperature > @pre_t AND DATEDIFF(Date, @pre_d) = 1 THEN Id ELSE NULL END AS Id,
@pre_t := 温度、@pre_d := 日付 
FROM Weather、(SELECT @pre_t := NULL, @pre_d := NULL) AS init ORDER BY Date ASC
) id が NULL ではない場合;

参考文献:

https://leetcode.com/discuss/33641/two-solutions

https://leetcode.com/discuss/52370/my-simple-solution-using-inner-join

https://leetcode.com/discuss/86435/a-simple-straightforward-solution-and-its-very-fast

これで、LeetCode (197. 気温上昇) の SQL 実装に関するこの記事は終了です。気温上昇の SQL 実装に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • LeetCode の SQL 実装 (196. 重複するメールボックスを削除する)
  • SQL 実装 LeetCode (185. 部門内で最も給与の高い上位 3 名)
  • LeetCode の SQL 実装 (184. 部門内で最も高い給与)
  • LeetCode の SQL 実装 (183. 注文をしたことがない顧客)
  • LeetCode の SQL 実装 (182. 重複するメールボックス)
  • LeetCode の SQL 実装 (181. 従業員は管理職よりも収入が高い)
  • SQLはLeetCodeを実装します(180.連続した数字)
  • LeetCode の C++ 実装 (組み合わせの最大数は 179)

<<:  検索ボックスのデフォルトテキストを設定します。マウスをクリックするとデフォルトテキストは消えます。

>>:  レスポンシブなアコーディオン効果を実現するための CSS3 の詳細な説明

推薦する

素晴らしいCSS属性MASKの詳しい説明

この記事では、CSS の非常に興味深い属性マスクを紹介します。名前が示すように、マスクはマスクと翻訳...

シングルサインオン制御を実装するためのVueの完全なコード

参考までに、Vue シングル サインオンのデモをご紹介します。詳細を知りたい方のお役に立てれば幸いで...

マウスを動かしたときに画像のズーム効果とゆっくりとした遷移​​効果を実現するCSSのサンプルコード

transform:scale()比例したズームインまたはズームアウトを実現できます。 transi...

Windows システムに MySQL を素早くインストールして展開する方法 (グリーンの無料インストール バージョン)

まずは緑色の無料インストール版のMySQLをダウンロードします。任意のフォルダに入れて構いません。今...

Centos7 での MySQL 5.7.20 のインストールと設定に関する詳細なチュートリアル

1. 公式 Web サイトから MySQL 5.7 インストール パッケージ (mysql-5.7....

MySQLとOracleのメタデータ抽出例分析

目次序文メタデータとは参照文書アドレスまずはMySQLについてお話しましょうOracleについて話し...

MySQL の自動インクリメント主キーが連続していないのはなぜですか?

目次1. はじめに2. 自己増分ストレージの説明3つの自己付加価値修正メカニズム4. 自己評価を修正...

MySQL 5.7 のユニオンオール使用法のブラックテクノロジーを 5 分で学ぶ

MySQL 5.6 での union all のパフォーマンスパート 1:MySQL 5.6.25 ...

Linux 7.7 でスワップ パーティション SWAP を設定する方法

Linux システムの Swap パーティション、つまり swap パーティションは、一般に仮想メモ...

Html+CSS フローティング広告ストリップの実装

1.html部分コードをコピーコードは次のとおりです。 <!DOCTYPE html> ...

Navicat がデータベース データ構造をインポートする際に発生するエラー datetime(0) の SQL レポートの問題を解決します。

エラー発生: MySQL 5.7 から SQL にデータベースをエクスポートし、それを MySQL ...

MySQLオンラインデータベースのデータをクリーンアップする方法

目次01 シナリオ分析02 操作方法03 結果分析01 シナリオ分析今日の午後、開発仲間がオンライン...

MySQLはテーブルデータを復元するためにfrmファイルとibdファイルを使用します

目次frm ファイルと ibd ファイルの紹介frm ファイル回復テーブル構造ibd ファイル回復テ...

12個のJavascriptテーブルコントロール(DataGrid)が整理されています

DataGrid コントロールの DataSource プロパティがデザイン時に設定されている場合、...