行列が対称かどうかをチェックするJavaScriptプログラム
対称行列は、行列と行列の転置の両方が同じである行列の特殊なケースです。行列とは、二次元配列に相当する、長方形の形で格納された整数または数値の集合であり、行列の転置も、すべての行を列に置き換えることによって得られる行列です。行列を取得し、それが対称行列であるかどうかを出力する必要があります。
###入力### リーリー ###出力### リーリーイラスト
ご存知のとおり、転置行列は列を行に、行を列に置き換えた行列です。したがって、ここでの最初の行は最初の列と同じであり、2 番目の行は同じです。 . 列と同じで、3 行目は列と同じです。
###入力### リーリー ###出力### リーリーイラスト
指定された行列では、転置行列は -
になります。 リーリー2 行目と 3 行目、または 2 列目と 3 列目が異なっていることがわかります。
Note- ご覧のとおり、特定の行列の転置は行と列を交換することで形成できます。つまり、行列の次元が N*M の場合、次の次元は行列は転置行列です。行列は M*N になります。これは、行列が対称であるためには、N が M に等しくなければならず、結果として正方行列になることを意味します。
単純な方法
この方法では、まず新しい行列を作成し、要素を行と列に格納することで転置行列を取得します。次に、両方の行列を単純に反復して比較します。どのインデックスでも一致しない場合は false を返し、一致しない場合は true を返します。
###例### リーリー時間と空間の複雑さ 上記のコードの時間計算量は O(N*N) です。ここで、N は指定された行列のサイズです。
転置された行列要素を格納するために余分なスペースを使用するため、上記のコードのスペース複雑さは O(N*N) です。
効率的な方法
転置行列は、行と列を交換することによって取得できます。つまり、各列は対応する行と等しくなります。したがって、任意のインデックス (i,j) の値は、指定された行列の (j,i) の値と等しくなります。
###例### リーリー時間と空間の複雑さ
上記のコードの時間計算量は O(N*N) です。ここで、N は指定された行列のサイズです。
余分なスペースを使用していないため、上記のコードのスペース複雑さは O(1) です。
###結論は###上記のチュートリアルでは、指定された行列が対称行列であるかどうかを確認する JavaScript コードを実装しました。対称行列は、行列と行列の転置の両方が同じである行列の特殊なケースであり、行列の転置は行と列を交換することで取得できます。行列が対称であるためには正方でなければなりません。時間計算量が O(N*N)、空間計算量が O(N*N)、空間計算量が O(1) の 2 つのメソッドを実装しました。
以上が行列が対称かどうかをチェックするJavaScriptプログラムの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









記事では、JavaScriptライブラリの作成、公開、および維持について説明し、計画、開発、テスト、ドキュメント、およびプロモーション戦略に焦点を当てています。

この記事では、ブラウザでJavaScriptのパフォーマンスを最適化するための戦略について説明し、実行時間の短縮、ページの負荷速度への影響を最小限に抑えることに焦点を当てています。

フロントエンドのサーマルペーパーチケット印刷のためのよくある質問とソリューションフロントエンド開発におけるチケット印刷は、一般的な要件です。しかし、多くの開発者が実装しています...

この記事では、ブラウザ開発者ツールを使用した効果的なJavaScriptデバッグについて説明し、ブレークポイントの設定、コンソールの使用、パフォーマンスの分析に焦点を当てています。

この記事では、ソースマップを使用して、元のコードにマッピングすることにより、Minified JavaScriptをデバッグする方法について説明します。ソースマップの有効化、ブレークポイントの設定、Chrome DevtoolsやWebpackなどのツールの使用について説明します。

この記事では、Javaのコレクションフレームワークの効果的な使用について説明します。 データ構造、パフォーマンスのニーズ、スレッドの安全性に基づいて、適切なコレクション(リスト、セット、マップ、キュー)の選択を強調しています。 コレクションの使用を効率的に最適化します

エントリーレベルのタイプスクリプトチュートリアルをマスターしたら、TypeScriptをサポートするIDEで独自のコードを作成し、JavaScriptにコンパイルできるはずです。このチュートリアルは、TypeScriptのさまざまなデータ型に飛び込みます。 JavaScriptには、NULL、未定義、ブール値、数字、文字列、シンボル(ES6によって導入)とオブジェクトの7つのデータ型があります。 TypeScriptはこれに基づいてより多くのタイプを定義し、このチュートリアルではすべてを詳細に説明します。 ヌルデータ型 JavaScriptのように、Typescriptのnull

このチュートリアルでは、chart.jsを使用してパイ、リング、およびバブルチャートを作成する方法について説明します。以前は、4つのチャートタイプのchart.js:ラインチャートとバーチャート(チュートリアル2)、およびレーダーチャートと極地域チャート(チュートリアル3)を学びました。 パイとリングチャートを作成します パイチャートとリングチャートは、さまざまな部分に分かれている全体の割合を示すのに理想的です。たとえば、パイチャートを使用して、サファリの男性ライオン、女性ライオン、若いライオンの割合、または異なる候補者が選挙で受け取る票の割合を示すことができます。 パイチャートは、単一のパラメーターまたはデータセットの比較にのみ適しています。パイチャートのファンの角度はデータポイントの数値サイズに依存するため、パイチャートは値のあるエンティティをゼロ値で描画できないことに注意してください。これは、割合がゼロのエンティティを意味します
