前回、データ構造としてのグラフについて書きましたが、グラフ アルゴリズムのテスト ポイントは最短経路問題だけです。 最短経路問題 最短経路問題: エッジに重みが付けられたネットワークが与えられた場合、パス上のエッジの重みの合計が最小になるように、指定された開始点から指定された終了点までのパスを見つけます。 たとえば、上の図では、図のポイント 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と脳コンピューターインターフェースへの野望を明らかにする
9月8日現在、コード作成を支援できるAI製品はすでに数多く市場に出回っている。本日の外灘大会サブフォ...
[51CTO.com クイック翻訳] 先週、Intel は分散型ディープラーニング用のオープンソース...
[[406953]]自動車メーカー、自動運転企業、バッテリーおよびエネルギー貯蔵企業として、テスラは...
人工知能の概念は長年提唱されてきたが、最近の流行は「人間対機械」の競争で囲碁の世界的名人、イ・セドル...
人工知能技術と他の技術の最大の違いは、人間の頭脳労働の一部を代替できるだけでなく、一部の分野では人間...
[[208216]] ***ニュースによると、Kaggleは最近、機械学習とデータサイエンスに関する...
この記事はAI新メディアQuantum Bit(公開アカウントID:QbitAI)より許可を得て転載...
2006 年 12 月、国際的に有名な学術組織である IEEE 国際データマイニング会議 (ICD...
機械学習は、さまざまな方法で Web ホスティング業界を変えています。 AWS などの多くのサードパ...
人類と新型コロナウイルスとの戦いは今も続いていますが、この間、さまざまな「人工知能+」アプリケーショ...
11月19日、アリババ、百度、ファーウェイ、テンセント、網易など国内有名企業が企画・主催する201...