Edmondsův algoritmus - Edmonds algorithm - Wikipedia

v teorie grafů, Edmondsův algoritmus nebo Algoritmus Chu – Liu / Edmonds je algoritmus pro nalezení a klenout se stromovost minimální hmotnosti (někdy označované jako optimální větvení) režie obdoba minimální kostra Algoritmus navrhli nezávisle nejprve Yoeng-Jin Chu a Tseng-Hong Liu (1965) a poté Jack Edmonds (1967).

Algoritmus

Popis

Algoritmus bere jako vstup směrovaný graf kde je sada uzlů a je sada směrovaných hran, rozlišující vrchol volal vykořenita skutečnou váhu pro každou hranu .Vrací rozpětí stromovost zakořeněné v minimální hmotnosti, kde je hmotnost arborescence definována jako součet jeho okrajových hmotností, .

Algoritmus má rekurzivní popis. Let označují funkci, která vrací spanning arborescence zakořeněnou na minimální hmotnosti. Nejprve odstraníme hranu jehož cílem je .Můžeme také nahradit jakoukoli sadu rovnoběžných hran (hrany mezi stejnou dvojicí vrcholů ve stejném směru) za jednu hranu s váhou rovnou minimu hmotností těchto rovnoběžných hran.

Nyní pro každý uzel kromě kořene najděte hranu přicházející do s nejnižší hmotností (s vazbami zlomenými libovolně). Označte zdroj této hrany pomocí Pokud je sada hran potom neobsahuje žádné cykly .

V opačném případě, obsahuje alespoň jeden cyklus. Volitelně vyberte jeden z těchto cyklů a zavolejte jej .Nyní definujeme nový vážený směrovaný graf ve kterém je cyklus je „zazmluvněno“ do jednoho uzlu takto:

Uzly jsou uzly ne v plus a Nový uzel označen .

  • Li je hrana v s a (hrana přicházející do cyklu), pak zahrnout do nový okraj a definovat .
  • Li je hrana v s a (hrana odcházející z cyklu), pak zahrňte dovnitř nový okraj a definovat .
  • Li je hrana v s a (hrana nesouvisející s cyklem), pak zahrnout do nový okraj a definovat .

Pro každý okraj dovnitř , pamatujeme si, který okraj dovnitř odpovídá.

Nyní najděte minimální klenutý strom z pomocí volání na .Od té doby je spanning arborescence, každý vrchol má přesně jednu příchozí hranu být jedinečnou příchozí hranou v .Tato hrana odpovídá hraně s .Odstraňte okraj z přerušením cyklu. Označte každou zbývající hranu dovnitř .Pro každý okraj dovnitř , označte jeho odpovídající hranu dovnitř .Nyní definujeme být sada označených hran, které tvoří minimální klenutý strom.

Dodržujte to je definován v pojmech , s mít přísně méně vrcholů než . Nález protože graf s jedním vrcholem je triviální (je to jen sám), takže je zaručeno ukončení rekurzivního algoritmu.

Provozní doba

Délka tohoto algoritmu je . Rychlejší implementace algoritmu díky Robert Tarjan běží v čase pro řídké grafy a pro husté grafy. Je to tak rychlé jako Primův algoritmus pro neorientovaný minimální kostru. V roce 1986 vytvořili Gabow, Galil, Spencer, Compton a Tarjan rychlejší implementaci s provozní dobou .

Reference

  • Chu, Y. J .; Liu, T. H. (1965), „On the Shortest Arborescence of a Directed Graph“, Science Sinica, 14: 1396–1400
  • Edmonds, J. (1967), „Optimum Branchings“, Journal of Research of the National Bureau of Standards Section B, 71B (4): 233–240, doi:10,6028 / jres.071b.032
  • Tarjan, R. E. (1977), "Hledání optimálních větví", Sítě, 7: 25–35, doi:10,1002 / net.3230070103
  • Camerini, P.M .; Fratta, L .; Maffioli, F. (1979), „Poznámka k hledání optimálních větví“, Sítě, 9 (4): 309–312, doi:10,1002 / net.3230090403
  • Gibbons, Alan (1985), Algoritmická teorie grafů, Cambridge University press, ISBN  0-521-28881-9
  • Gabow, H. N .; Galil, Z .; Spencer, T .; Tarjan, R. E. (1986), „Efektivní algoritmy pro hledání stromů s minimálním rozpětím v neorientovaných a směrovaných grafech“, Combinatorica, 6 (2): 109–122, doi:10.1007 / bf02579168

externí odkazy