検索
ホームページバックエンド開発PHPチュートリアルすべて 1 で正方部分行列を数える

Count Square Submatrices with All Ones

1277。平方部分行列をすべて 1 で数えます

難易度:

トピック: 配列、動的計画法、行列

1 と 0 からなる m * n 行列を指定すると、すべて 1 を持つ 正方形 部分行列がいくつあるかを返します。

例 1:

  • 入力: 行列 = [[0,1,1,1], [1,1,1,1], [0,1,1,1]]
  • 出力: 15
  • 説明:
    • 辺 1 には 10 個の正方形があります。
    • 辺 2 には 4 個の正方形があります。
    • 辺 3 には 1 個の正方形があります。
    • 正方形の合計数 = 10 4 1 = 15.

例 2:

  • 入力: 行列 = [[1,0,1], [1,1,0], [1,1,0]]
  • 出力: 7
  • 説明:
    • 1面は6マスあります。
    • 辺 2 の正方形が 1 つあります。
    • 正方形の合計数 = 6 1 = 7。

制約:

  • 1
  • 1
  • 0

ヒント:

  1. (0,0) を上位コーナーとする 部分行列 の要素の合計をカウントする加算テーブルを作成します。
  2. O(n3) のすべての subsquare をループし、合計により配列全体が 1 になるかどうかを確認します。確認された場合は、答えに 1 を加えます。

解決策:

動的計画法 (DP) を使用して、行列内の各セルで終わるすべて 1 の正方部分行列の数を追跡できます。これを達成するためのアプローチは次のとおりです:

  1. DP マトリックス定義:

    • DP 行列 dp を定義します。ここで、dp[i][j] は、セル (i, j) に右下隅を持つすべて 1 の最大正方部分行列のサイズを表します。
  2. 遷移式:

    • 行列の各セル (i, j) について:

      • matrix[i][j] が 1 の場合、dp[i][j] の値は、(i-1, j), (i, j) から拡張して形成できる正方形の最小値に依存します。 -1)、および (i-1、j-1)。遷移式は次のとおりです。
      dp[i][j] = min(dp[i-1][j], dp[i][j-1], dp[i-1][j-1]) + 1
      
  - If `matrix[i][j]` is 0, `dp[i][j]` will be 0 because a square of ones cannot end at a cell with a zero.
  1. すべての正方形を数える:

    • すべての (i, j) の dp[i][j] の値を累積して、すべてのサイズの正方形の合計数を取得します。
  2. 時間計算量:

    • この解決策は O(m X n) で機能します。ここで、m および n は行列の次元です。

このソリューションを PHP で実装してみましょう: 1277。平方部分行列をすべて 1 で数えます

dp[i][j] = min(dp[i-1][j], dp[i][j-1], dp[i-1][j-1]) + 1

説明:

  1. 各位置 (i, j) で終わる最大の正方部分行列のサイズを追跡するために、2D 配列 dp を初期化します。
  2. 行列内の各セルについて:
    • セルに 1 がある場合、隣接するセルに基づいて dp[i][j] を計算し、その値を totalSquares に追加します。
  3. 最後に、totalSquares には、すべて 1 であるすべての正方部分行列の数が含まれます。

この解決策は効率的であり、問​​題で指定された制約を満たしています。

連絡先リンク

このシリーズが役立つと思われた場合は、GitHub で リポジトリ にスターを付けるか、お気に入りのソーシャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!

このような役立つコンテンツがさらに必要な場合は、お気軽にフォローしてください:

  • LinkedIn
  • GitHub

以上がすべて 1 で正方部分行列を数えるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPで__CLONEメソッドを使用する方法は?PHPで__CLONEメソッドを使用する方法は?May 15, 2025 pm 08:48 PM

PHPの__Cloneメソッドは、オブジェクトクローン時にカスタム操作を実行するために使用されます。クローンキーワードを使用してオブジェクトをクローニングする場合、オブジェクトに__クローンメソッドがある場合、メソッドが自動的に呼び出され、クローン型属性をリセットしてクローンオブジェクトの独立性を確保するなど、クローンプロセス中にカスタマイズされた処理を許可します。

PHPでGOTOステートメントを使用する方法は?PHPでGOTOステートメントを使用する方法は?May 15, 2025 pm 08:45 PM

PHPでは、GOTOステートメントは、プログラムの特定のタグに無条件にジャンプするために使用されます。 1)複雑なネストされたループまたは条件付きステートメントの処理を簡素化することができますが、2)GOTOを使用すると、コードの理解と維持が困難になる場合があります。3)構造化された制御ステートメントの使用を優先することをお勧めします。全体として、gotoは注意して使用する必要があり、コードの読みやすさと保守性を確保するために、ベストプラクティスに従う必要があります。

PHPにデータ統計を実装する方法は?PHPにデータ統計を実装する方法は?May 15, 2025 pm 08:42 PM

PHPでは、組み込み関数、カスタム関数、およびサードパーティライブラリを使用してデータ統計を実現できます。 1)array_sum()やcount()などの組み込み関数を使用して、基本統計を実行します。 2)カスタム関数を記述して、中央値などの複雑な統計を計算します。 3)PHP-MLライブラリを使用して、高度な統計分析を実行します。これらの方法により、データ統計を効率的に実行できます。

PHPで匿名関数を使用する方法は?PHPで匿名関数を使用する方法は?May 15, 2025 pm 08:39 PM

はい、PHPの匿名関数は、名前のない関数を参照します。これらは、他の関数へのパラメーターとして、および関数の返品値として渡すことができ、コードをより柔軟で効率的にします。匿名関数を使用する場合、範囲とパフォーマンスの問題に注意を払う必要があります。

PHPでarray_randでキーをランダムに取得するにはどうすればよいですか?PHPでarray_randでキーをランダムに取得するにはどうすればよいですか?May 15, 2025 pm 08:36 PM

PHPでは、array_rand関数を使用して、配列からランダムにキーを取得できます。 1)array_rand($ array)を使用して、単一のランダムキーを取得します。 2)array_rand($ array、n)を使用して、nランダムキーを取得します。この機能は効率的で柔軟ですが、大規模なデータの主要なカウントとパフォーマンスの問題の制限に注意を払う必要があります。

PHPで機能のホットアップデートを実装する方法は?PHPで機能のホットアップデートを実装する方法は?May 15, 2025 pm 08:33 PM

PHPに機能のホットアップデートを実装するには、次の3つの方法があります。 2。opcacheを使用して、opcacheを再起動してホットアップデートを実現します。 3.展開やAnsibleなどの外部ツールを使用して、コードを自動的に展開および更新します。

PHPアレイを反復しながら要素を交換する方法は?PHPアレイを反復しながら要素を交換する方法は?May 15, 2025 pm 08:30 PM

PHPでは、次の方法を使用して配列要素を横断および交換できます。1。foreachループと参照(&$値)を使用して要素を変更しますが、参照が副作用を引き起こす可能性があることに注意してください。 2。forループを使用して、インデックスと値に直接アクセスして、参照の問題を回避します。 3. array_map関数を使用して簡潔な変更を加えますが、キー名はリセットされます。 4. array_walk関数を使用して値を変更し、キー名を保持します。方法を選択する際には、パフォーマンス、副作用、キー名保持要件を考慮する必要があります。

PHPでISBN文字列を検証する方法は?PHPでISBN文字列を検証する方法は?May 15, 2025 pm 08:27 PM

PHPのISBN文字列の検証は、ISBN-10とISBN-13の2つの形式を処理できる関数を介して実装できます。 1.すべての非数字を削除します。 2。ISBN-10の場合、加重和の計算が使用され、結果を11。3で割ることができる場合は有効です。ISBN-13の場合、異なる重み付け和の計算を使用し、結果を10で割ることができる場合は有効です。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境