前回、データ構造としてのグラフについて書きましたが、グラフ アルゴリズムのテスト ポイントは最短経路問題だけです。 最短経路問題 最短経路問題: エッジに重みが付けられたネットワークが与えられた場合、パス上のエッジの重みの合計が最小になるように、指定された開始点から指定された終了点までのパスを見つけます。 たとえば、上の図では、図のポイント 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と脳コンピューターインターフェースへの野望を明らかにする
COVID-19の流行は中国の武漢で最初に発生して以来、少なくとも100の国と地域に広がっています。...
[[341971]]シノベーションベンチャーズの会長兼CEOである李開復氏は9月12日、HICOO...
データ準備の最も一般的なアプローチは、データセットを調査し、機械学習アルゴリズムの期待値を確認し、最...
古典的なデータマイニングアルゴリズムのトップ 10 は次のとおりです。導入C4.5 は決定木アルゴリ...
[[190049]]この記事は、4月27日にBig Data Talk WeChatコミュニティで...
[[349269]] 2020年に世界的パンデミックが発生し、世界が完全にひっくり返る前から、人工知...
「ついていけない人は排除されるかもしれない」ソラのデモ動画を見て、10年以上の経験を持つアニメプロ...
[[348074]]自動運転車でディープラーニングを使用すると、歩行者の行動を理解したり、最短ルー...
[[207730]] Microsoft は、Apache Spark 用のディープラーニング ライ...
[[435758]]序文モノのインターネット (IoT) の発展により、さまざまな無線信号 (Wi...
マンデルブロ複素集合: https://en.wikipedia.org/wiki/Mandelbr...
Big Language Model が世界モデルであるという新たな証拠!少し前、MITとノースイー...
現在、ニューラル表現は、レンダリング、イメージング、幾何学モデリング、シミュレーション アプリケーシ...