Dijkstrov algoritem
Iz Wikipedije, proste enciklopedije
Dijkstrov algoritem ali drevo najkrajših poti se uporablja za iskanje drevesa najkrajših poti. Dijkstra je razvil algoritem za drevo najkrajših poti z požrešno metodo. Drevo najkrajših poti gradimo korak za korakom. Naj bo T množica povezav, ki so že v drevesu. V drevo sprejmem novo povezavo e = (v,u) ∈ E in sicer tako, da naredim unijo T ∪ {e}. Da bo ta unija T ∪ {e} tudi drevo, mora biti natanko eno vozlišče, v ali u, že v drevesu T.
Predpostavimo, da je vozlišče v že v drevesu. Povezavo e = (v,u) lahko sprejmemo, če najkrajša pot od začetnega vozlišča do vozlišča u sme teči le po povezavah, ki so že v drevesu. Torej ne sme obstajati vozlišče w, ki ni v drevesu, takšno, da je pot iz izvora preko w do u krajša krajša kot po povezavah, ki že v drevesu. Da je pot od izvornega vozlišča do vozlišča u preko vozlišč, ki so v drevesu krajša, pa mora veljati, da so vsa vozlišča w (to so vozlišča, ki niso v drevesu) kvečjemu bolj oddaljena od izvora, kot je vozlišče u.
Pri drevesu najkrajših poti imamo usmerjen graf.
[uredi] Zahtevnost
Časovna zahtevnost algoritma je Θ(n2), ker mora algoritem preveriti vsako povezavo najmanj 1. krat, teh povezav pa je v grafu z n vozlišči n*(n-1) saj gre za polni graf.
[uredi] Splošna procedura
1. V drevesu T še ni nobenega vozlišča, zato je podatek oče[i] za vsa vozlišča enak 0. 2. V drevo T dodam začetno vozlišče. oče[začetno vozlišče] = 0 razdalja[začetno_vozlišče] = 0, torej razdalja od začetnega do začetnega vozlišča je 0 zadnje vstavljeno vozlišče je začetno vozlišče 3. Pojdi čez vse vozlišča, ki še niso v drevesu, torej skozi vsa vozlišča razen začetnega vozlišča in določi vozlišče, ki je najbližje začetnemu vozlišču direktno in ga vključi v rešitev in sicer: oče[u] = začetno vozlišče zadnje vstavljeno vozlišče je u osvežim razdalje Za tista vozlišča, ki še niso v drevesu, določimo razdaljo do začetnega vozlišča tako, da vzamemo minimum med razdaljo na prejšnjem koraku, izračunano razdaljo od tega vozlišča preko vozlišč, ki so že v drevesu ter razdaljo med začetnim vozliščem in vozlišči, ki so v listih drevesa n. Jim prištejemo še pot iz vozlišča, ki je list, do trenutno obravnavanega vozlišča. 4. Ponavljaj tretji korak, dokler niso vsa vozlišča v drevesu