前回、データ構造としてのグラフについて書きましたが、グラフ アルゴリズムのテスト ポイントは最短経路問題だけです。 最短経路問題 最短経路問題: エッジに重みが付けられたネットワークが与えられた場合、パス上のエッジの重みの合計が最小になるように、指定された開始点から指定された終了点までのパスを見つけます。 たとえば、上の図では、図のポイント 1 からポイント 4 までの最短経路の長さは 3 (1 から 2 から 4) になります。 最短経路問題はダイクストラ法で解かれることが多い。 ダイクストラアルゴリズム ダイクストラ アルゴリズムは、1 つのノードから他のすべてのノードまでの最短パスを計算するために使用される、典型的な単一ソース最短パス アルゴリズムです。開始点を中心に層ごとに外側に広がり、終了点に到達するのが最大の特徴です。 例えば、上図のダイクストラアルゴリズムは、開始ノードから隣接ノードまでのすべてのパスを継続的に検索し、初期距離を最短距離に設定し、最も遠いノードまでの最短距離が解決されるまで、隣接ノードの最短距離を継続的に更新するプロセスです。 テキストの説明が明確ではありません。下のアニメーション画像を参照してください。 グラフ上の頂点は、訪問済みノードと未訪問ノードの 2 つのセットに分割されます。 ポイントが訪問先から外側に拡張されるたびに、拡張ルールは更新可能なポイント間の距離が最小になるようにすることです。 上の写真を例に挙げてみましょう まず、隣接行列を使用して無向グラフを表します。
隣接行列g[0][1]=1は、最初のノードから2番目のノードまでの距離が1であることを意味します。 目的は、出発点1から他の点までの最短経路距離を見つけることです。
これまでのところ、ノード 1 から残りの 3 つのノードまでの最短距離は 1、4、および 5 です。 「重み付けされていないグラフ、つまりすべてのエッジの重みが等しいグラフにダイクストラのアルゴリズムを適用することは、BFS 検索と同等です。」 その他のソリューション 多くの場合、無向グラフの最短経路を取得するには、一連の点を入力し、開始点を入力する必要があります。
テストケース
テストケースでは、0 1 1 は最初の頂点から 2 番目の頂点までの距離が 1 であることを意味します。 隣接リストを使用したダイクストラのアルゴリズムの時間計算量は次のとおりです。そのため、多くの場合、最適化のためにヒープを使用したり、余分なスペースを最適化するためにハッシュ テーブルを使用したりします。 |
>>: ザッカーバーグの45分間の詳細なインタビュー:今後10年間のVRと脳コンピューターインターフェースへの野望を明らかにする
[[318187]]私たちはインテリジェント変革の時代に生きており、人工知能技術はあらゆる分野の人...
以下の記事では、主にハッカーがGSMアルゴリズムをクラックし、携帯電話ユーザーが盗聴の危険にさらされ...
この記事は、Heart of Autonomous Driving の公開アカウントから許可を得て転...
職場復帰の日が近づくにつれ、全国で生産や業務が徐々に再開されているが、同時に防疫活動も緩めてはならな...
フォーブスによると、人工知能(AI)によって人間の仕事が失われ、広範囲にわたる人員削減が起こると広く...
[[248203]]バイオテクノロジーの進歩により、人間の寿命は今後も延び続け、社会の家族構成、結婚...
ハリー・ポッターの世界では、組分け帽子は生徒の行動履歴、好み、性格に関するデータを取得し、そのデータ...
10月28日、サンフランシスコのニュース予報では、29日の強風により再び停電が発生するだろうと報じら...
[[259079]] AI の応用により予測コストが大幅に削減され、企業はますます新しい、予想外の方...
約 1 年前、私はファイルからデータ、主にテーブルに含まれるデータを抽出して構造化するタスクを割り当...
[[431427]]この記事はWeChatの公開アカウント「3分でフロントエンドを学ぶ」から転載した...
[[412540]]この記事はAI新メディアQuantum Bit(公開アカウントID:QbitAI...