DAA-スパニングツリー
A spanning tree は、すべての頂点が最小数のエッジで接続されている無向グラフのサブセットです。
すべての頂点がグラフで接続されている場合、少なくとも1つのスパニングツリーが存在します。グラフには、複数のスパニングツリーが存在する場合があります。
プロパティ
- スパニングツリーにはサイクルがありません。
- 他の頂点から任意の頂点に到達できます。
例
次のグラフでは、強調表示されたエッジがスパニングツリーを形成しています。
最小スパニングツリー
A Minimum Spanning Tree (MST)は、接続された重み付き無向グラフのエッジのサブセットであり、すべての頂点を可能な限り最小の合計エッジ重みで接続します。MSTを導出するには、プリムのアルゴリズムまたはクラスカルのアルゴリズムを使用できます。したがって、この章ではプリムのアルゴリズムについて説明します。
すでに説明したように、1つのグラフに複数のスパニングツリーが含まれる場合があります。ある場合n 頂点の数、スパニングツリーは n - 1エッジの数。このコンテキストでは、グラフの各エッジが重みに関連付けられており、複数のスパニングツリーが存在する場合、グラフの最小スパニングツリーを見つける必要があります。
さらに、重複する重み付きエッジが存在する場合、グラフには複数の最小全域木が含まれる可能性があります。
上のグラフでは、最小スパニングツリーではありませんが、スパニングツリーを示しています。このスパニングツリーのコストは(5 + 7 + 3 + 3 + 5 + 8 + 3 + 4)= 38です。
プリムのアルゴリズムを使用して、最小全域木を見つけます。
プリムのアルゴリズム
プリムのアルゴリズムは、最小全域木を見つけるための欲張り法です。このアルゴリズムでは、MSTを形成するために、任意の頂点から開始できます。
Algorithm: MST-Prim’s (G, w, r)
for each u є G.V
u.key = ∞
u.∏ = NIL
r.key = 0
Q = G.V
while Q ≠ Ф
u = Extract-Min (Q)
for each v є G.adj[u]
if each v є Q and w(u, v) < v.key
v.∏ = u
v.key = w(u, v)
関数Extract-Minは、最小のエッジコストで頂点を返します。この関数は最小ヒープで機能します。
例
プリムのアルゴリズムを使用して、任意の頂点から開始できます。頂点から開始しましょう。 1。
バーテックス 3 頂点に接続されています 1 最小のエッジコストで、したがってエッジ (1, 2) スパニングツリーに追加されます。
次に、エッジ (2, 3) これはエッジ間の最小値であるため、 {(1, 2), (2, 3), (3, 4), (3, 7)}。
次のステップでは、エッジを取得します (3, 4) そして (2, 4)最小限のコストで。縁(3, 4) ランダムに選択されます。
同様に、エッジ (4, 5), (5, 7), (7, 8), (6, 8) そして (6, 9)が選択されています。すべての頂点にアクセスすると、アルゴリズムが停止します。
スパニングツリーのコストは(2 + 2 + 3 + 2 + 5 + 2 + 3 + 4)= 23です。このグラフには、コストが以下のスパニングツリーはありません。 23。