[LeetCode] 180. 連続した数字少なくとも 3 回連続して出現するすべての数字を検索する SQL クエリを記述します。
たとえば、上記の Logs テーブルでは、少なくとも 3 回連続して出現する数字は 1 だけです。 この問題では、Logs テーブルが提供され、Num 列に同じ数字が 3 回連続して出現する数字を見つけるように求められます。同じ数字を 3 回見つける必要があるため、3 つのテーブル インスタンスを作成する必要があります。l1 を使用して、それぞれ l2 および l3 と交差し、l1 の次の位置と l2 の Id を比較し、l1 と l3 の次の 2 つの位置を比較して、同じ Num を持つ数字を返します。 解決策1: SELECT DISTINCT l1.Num FROM Logs l1 JOIN ログ l2 ON l1.Id = l2.Id - 1 JOIN ログ l3 ON l1.Id = l3.Id - 2 ここで、l1.Num = l2.Num かつ l2.Num = l3.Num; 次のメソッドは Join を使用せず、3 つのテーブルのインスタンス内を直接検索し、4 つの条件を制限して正しい結果を返します。 解決策2: Logs l1、Logs l2、Logs l3 から DISTINCT l1.Num を選択 ここで、l1.Id = l2.Id - 1 かつ l2.Id = l3.Id - 1 かつ、l1.Num = l2.Num かつ、l2.Num = l3.Num; まったく異なる方法を見てみましょう。変数 count と pre が使用され、それぞれ 0 と -1 に初期化されます。次に、IF 文が使用されていることに注意してください。MySQL の IF 文は、私たちがよく知っている他の言語の if 文とは異なります。これは、おなじみの三項演算子 a?b:c に相当します。a が true の場合は b を返し、そうでない場合は c を返します。それでは、まず Num 列の最初の数字 1 を見てみましょう。pre は現在の Num とは異なる -1 に初期化されているため、この時点で count には 1 が割り当てられ、この時点で pre には 1 が割り当てられます。次に、Num 列の 2 番目の 1 が入り、この時点で pre は Num と同じです。count は 1 増加します。Num 列の 3 番目の 1 が入ると、count は 3 に増加します。この時点で、where 条件が満たされ、tn >= 3 であるため、1 が選択されます。このようにして、Num 全体を走査して最終結果を取得します。 解決策3: SELECT DISTINCT 数値 FROM ( SELECT Num, @count := IF(@pre = Num, @count + 1, 1) AS n, @pre := Num ログから、(SELECT @count := 0, @pre := -1) AS init ) AS t ここで tn >= 3; 参考文献: https://leetcode.com/discuss/54463/シンプルソリューション https://leetcode.com/discuss/87854/simple-sql-with-join-1484-ms https://leetcode.com/discuss/69767/two-solutions-inner-join-and-two-variables これで、LeetCode (180. 連続数) の SQL 実装に関するこの記事は終了です。 連続数の SQL 実装に関するより関連性の高いコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。 今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: Pengyou.com モバイル クライアントのダウンロード ページのデザイン共有 (画像とテキスト)
借財宝は最近人気が出ている携帯電話ローンソフトウェアプラットフォームです。知人同士の貸し借りが特徴で...
まずは効果の写真をお見せしましょう。 個人的には効果は問題ないと思います。アプリが写真を学習する時間...
参考までに、クリックナンバーゲームをネイティブJSで実装しました。具体的な内容は以下のとおりです。最...
目次序文子コンポーネントは親コンポーネントにデータを渡す1. 親コンポーネントから子コンポーネントに...
目次1. コンポーネントの紹介2. ソースコード分析2.1 テンプレート2.2 スクリプト2.3 実...
1. コンポーネントの実装方法:組件名稱首字母必須大寫1. JS関数を通じてコンポーネントを実装...
テキストシャドウ text-shadow プロパティの効果: 1. 右下隅の影、左下隅の影、左上隅の...
コードをコピーコードは次のとおりです。 <スタイル> .fileInputContain...
1. 以前 QT5.13 バージョンをダウンロードしましたが、インストール後、Qtcreator を...
前面に書かれた注文テーブル、アクセス記録テーブル、商品テーブルなど、日常生活でデータベースを操作する...
1. Dockerのインストールと設定 #CentOS をインストールし、Docker パッケージを...
1. MySQLデータベースの構成と関連概念まず、MySQL はリレーショナル データベースである...
目次1. マスタースレーブレプリケーションマスタースレーブレプリケーション3スレッドマスタースレーブ...
Web アプリケーション クラス1. みんなのためにダウンまたは私だけのためにこのウェブサイトは、ウ...
この記事では、マルチカラムレイアウトドラッグを実装するためのVueの具体的なコードを参考までに共有し...