]> mj.ucw.cz Git - ga.git/blob - 5-mst/5-mst.tex
44a8e339bd6264ee4f3d89b6d88218a91bb58b2a
[ga.git] / 5-mst / 5-mst.tex
1 \input ../sgr.tex
2 \prednaska{5}{Minimální kostry}{}
3
4 \def\symdiff{\mathop{\Delta}}
5
6 \>Tato kapitola uvede problém minimální kostry, základní vìty o~kostrách a klasické
7 algoritmy na~hledání minimálních koster. Budeme se inspirovat Tarjanovým pøístupem
8 z~knihy~\cite{tarjan:dsna}. V¹echny grafy v~této kapitole budou neorientované multigrafy
9 a jejich hrany budou ohodnoceny vahami $w: E \to {\bb R}$.
10
11 \todo{Chybí zde obrázky, znaènì by hutný text projasnily.}
12
13 \h{Minimální kostry a jejich vlastnosti}
14
15 \s{Definice:}
16 \itemize\ibull
17 \:{\I Podgrafem} budeme v~této kapitole mínit libovolnou podmno¾inu hran, vrcholy
18 v¾dy zùstanou zachovány.
19 \:{\I Pøidání a odebrání hrany} budeme znaèit $T+e:=T\cup \{e\}$, $T-e:=T\setminus \{e\}$.
20 \:{\I Kostra} (Spanning Tree) souvislého grafu $G$ je libovolný jeho podgraf, který je strom.
21 Kostru nesouvislého grafu definujeme jako sjednocení koster jednotlivých komponent.
22 [Alternativnì: kostra je minimální podgraf, který má komponenty s~tými¾ vrcholy
23 jako komponenty~$G$.]
24 \:{\I Váha} podgrafu $F\subseteq E$ je $w(F) := \sum_{e\in F} w(e)$.
25 \:{\I Minimální kostra} (Minimum Spanning Tree, mezi pøáteli té¾ MST) budeme øíkat
26 ka¾dé kostøe, její¾ váha je mezi v¹emi kostrami daného grafu minimální.
27 \endlist
28
29 Toto je sice standardní definice MST, ale jinak je dosti ne¹ikovná, proto¾e vy¾aduje,
30 aby bylo váhy mo¾né sèítat. Za~chvíli si uká¾eme, ¾e to není potøeba.
31
32 \s{Definice:}
33 Buï $T \subseteq G$ nìjaká kostra grafu~$G$. Pak:
34 \itemize\ibull
35 \:$T[x,y]$ bude znaèit cestu v~$T$, která spojuje $x$ a $y$. (Cestou opìt míníme mno¾inu hran.)
36 \:$T[e]:=T[x,y]$ pro hranu $e=xy$. Této cestì budeme øíkat {\I cesta pokrytá hranou~$e$.}
37 \:Hrana $e\in E \setminus T$ je {\I lehká vzhledem k~$T$} $\equiv \exists e^\prime \in T[e]: w(e)<w(e^\prime)$.
38   Ostatním hranám nele¾ícím v~kostøe budeme øíkat {\I tì¾ké.}
39 \endlist
40
41 \s{Vìta:} Kostra~$T$ je minimální $\Leftrightarrow$ neexistuje hrana lehká vzhledem k~$T$.
42
43 Tato vìta nám dává pìknou alternativní definici MST, která místo sèítání vah váhy
44 pouze porovnává, èili jí místo èísel staèí (kvazi)uspoøádání na~hranách. Ne¾ se dostaneme
45 k~jejímu dùkazu, prozkoumejme nejdøíve, jak se dá mezi jednotlivými kostrami pøecházet.
46
47 %\centerline{\epsfysize=3cm\epsfbox{01.eps}}
48
49 \s{Definice:} Pro kostru~$T$ a hrany $e, e'$
50 zaveïme $\<swap>(T,e,e^\prime) := T-e+e'$.
51
52 \s{Pozorování:}
53 Pokud $e^\prime \not\in T$ a $e\in T[e^\prime]$, je $\<swap>(T,e,e^\prime)$ opìt kostra.
54 Staèí si uvìdomit, ¾e pøidáním $e^\prime$ do~$T$ vznikne kru¾nice (konkrétnì $T[e^\prime] + e^\prime$)
55 a vynecháním libovolné hrany z~této kru¾nice získáme opìt kostru.
56
57 \s{Lemma o~swapování:}
58 Máme-li libovolné kostry $T$ a $T'$, pak lze z~$T$ dostat $T'$ koneèným poètem operací \<swap>.
59
60 \proof
61 Jeliko¾ $\vert T \vert = \vert T' \vert$, musí existovat $e' \in T'\setminus T$.
62 Kru¾nice $T[e']+e'$ nemù¾e být celá obsa¾ena v~$T$, tak¾e existuje hrana
63 $e\in T[e']\setminus T'$ a $\check{T} := \<swap>(T,e,e')$ je kostra,
64 pro kterou $\vert \check{T} \symdiff T' \vert = \vert T \symdiff T' \vert -2$.
65 Po~koneèném poètu tìchto krokù tedy musíme dojít k~$T'$.
66 \qed
67
68 \s{Monotónní lemma o~swapování:}
69 Je-li $T$ kostra, k~ní¾ neexistují ¾ádné lehké hrany, a~$T'$ libovolná kostra,
70 pak lze od~$T$ k~$T'$ pøejít posloupností swapù, pøi které váha kostry neklesá.
71
72 \proof
73 Podobnì jako u~pøedchozího lemmatu budeme postupovat indukcí podle $\vert T \symdiff T' \vert$.
74 Pokud zvolíme libovolnì hranu $e'\in T'\setminus T$ a k~ní $e\in T[e']\setminus T'$, musí
75 $\check{T}:=\<swap>(T,e,e')$ být kostra bli¾¹í k~$T'$ a $w(\check{T})\ge w(T)$,
76 jeliko¾ $e'$ nemù¾e být lehká vzhledem k~$T$, tak¾e speciálnì $w(e')\ge w(e)$.
77
78 Aby mohla indukce pokraèovat, potøebujeme je¹tì dokázat, ¾e ani k~nové kostøe neexistují
79 lehké hrany v~$T'\setminus \check{T}$. K~tomu nám pomù¾e zvolit si ze~v¹ech mo¾ných hran~$e'$ tu s~nejmen¹í vahou.
80 Uva¾me nyní hranu~$f\in T'\setminus \check{T}$.
81 Cesta $\check{T}[f]$ pokrytá touto hranou v~nové kostøe je buïto pùvodní $T[f]$ (to pokud $e\not\in T[f]$)
82 nebo $T[f] \symdiff C$, kde $C$ je kru¾nice $T[e']+e$. První pøípad je triviální,
83 ve~druhém si staèí uvìdomit, ¾e $w(f)\ge w(e')$ a ostatní hrany na~$C$ jsou lehèí
84 ne¾~$e'$.
85 \qed
86
87 \s{Dùkaz vìty:}
88 \itemize\ibull
89 \:$\Rightarrow$ Chceme dokázat, ¾e $\exists$ lehká hrana $\Rightarrow$ $T$ není minimální.
90
91 Nech» $\exists e$ lehká. Najdeme $e' \in T[e] : w(e) < w(e')$ (ta musí existovat z def. lehké hrany).
92 Kostra $T' := \<swap>(T,e,e')$ je lehèí ne¾~$T$.
93
94 \medskip
95
96 \:$\Leftarrow$ Pokud k~$T$ neexistuje lehká hrana, je $T$ minimální.
97
98 Uva¾me nìjakou minimální kostru $T_{min}$ a pou¾ijme monotónní swapovací lemma na~$T$ a $T_{min}$. Z~nìj plyne $w(T)\le w(T_{min})$,
99 a~tedy $w(T)=w(T_{min})$.
100 \qeditem
101 \endlist
102
103 \s{Vìta:}
104 Jsou-li v¹echny váhy hran navzájem rùzné, je MST urèena jednoznaènì.
105
106 \proof
107 Máme-li dvì MST $T_1$ a $T_2$, neobsahují podle pøedchozí vìty lehké hrany, tak¾e podle monotónního
108 lemmatu mezi nimi lze pøeswapovat bez poklesu váhy. Pokud jsou ale váhy rùzné, musí ka¾dé swapnutí
109 ostøe zvý¹it váhu, a~proto k~¾ádnému nemohlo dojít.
110 \qed
111
112 \s{Poznámka:} Èasto se nám bude hodit, aby kostra, kterou hledáme, byla urèena jednoznaènì.
113 Tehdy mù¾eme vyu¾ít pøedchozí vìty a váhy zmìnit o~vhodné epsilony, respektive kvaziuspoøádání
114 roz¹íøit na~lineární uspoøádání.
115
116 \h{Èervenomodrý meta-algoritmus}
117
118 V¹echny tradièní algoritmy na~hledání MST lze popsat jako speciální pøípady následujícího
119 meta-algoritmu. Rozeberme si tedy rovnou ten. Formulujeme ho pro pøípad, kdy jsou v¹echny
120 váhy hran navzájem rùzné.
121
122 \s{Meta-algoritmus:}
123
124 \algo
125 \:Na poèátku jsou v¹echny hrany bezbarvé.
126 \:Dokud to lze, pou¾ijeme jedno z~následujících pravidel:
127 \::{\I Modré pravidlo:} Vyber øez takový, ¾e jeho nejlehèí hrana není modrá,\foot{Za
128 touto podmínkou nehledejte ¾ádná kouzla, je tu pouze proto, aby se algoritmus nemohl
129 zacyklit neustálým provádìním pravidel, která nic nezmìní.} a obarvi ji na~modro.
130 \::{\I Èervené pravidlo:} Vyber cyklus takový, ¾e jeho nejtì¾¹í hrana není èervená, a obarvi ji na~èerveno.
131 \endalgo
132
133 \s{Vìta:}
134 Pro Èervenomodrý meta-algoritmus spu¹tìný na~libovolném grafu s~hranami lineárnì uspoøádanými
135 podle vah platí:
136 \algo
137 \:V¾dy se zastaví.
138 \:Po zastavení jsou v¹echny hrany obarvené.
139 \:Modøe obarvené hrany tvoøí minimální kostru.
140 \endalgo
141
142 \s{Modré lemma:} Je-li hrana~$e$ kdykoliv algoritmem obarvena na~modro, pak $e\in T_{min}$.
143
144 \proof Minimální kostra $T_{min}$ je urèena jednoznaènì (váhy jsou rùzné).
145 Hrana~$e$ byla omodøena jako nejlehèí hrana nìjakého øezu~$C$.
146 Pokud by existovala nìjaká jiná $e' \in C \cap T_{min}[e]$, mù¾eme provést
147 $\<swap>(T_{min},e',e)$ a tím z~$T_{min}$ vytvoøit je¹tì lehèí kostru,
148 co¾ je spor.
149 \qed
150
151 \fig{02.eps}{3cm}
152
153 \s{Èervené lemma:} Je-li hrana~$e$ kdykoliv algoritmem obarvena na~èerveno, pak $e\not\in T_{min}$.
154
155 \proof Opìt sporem: Pøedpokládejme, ¾e~$e$ byla obarvena èervenì jako nejtì¾¹í na~nìjaké kru¾nici~$C$
156 a ¾e $e\in T_{min}$. Odebráním~$e$ se nam $T_min$ rozpadne na dvì komponenty $T_x$ a $T_y$.
157 Nìkteré vrcholy kru¾nice pøipadnou do komponenty $T_x$, ostatní do $T_y$.
158 Lze jednodu¹e nahlédnout, ¾e musí existovat hrana $e'\ne e$ taková, ¾e $x' \in T_x$ a $y' \in T_y$.
159 Hrana~$e$ byla nejtì¾¹í na~kru¾nici, tak¾e $w(e') < w(e)$ a $\<swap>(T_{min},e,e')$ nám dá~lehèí kostru,
160 co¾ je spor.
161 \qed
162
163 \fig{03.eps}{4cm}
164
165 \s{Bezbarvé lemma:} Pokud existuje nìjaká neobarvená hrana, lze je¹tì pou¾ít nìkteré
166 z~pravidel.
167
168 \proof Nech» existuje hrana~$e=xy$, která je stále bezbarvá. Oznaèíme si $M$ mno¾inu vrcholù,
169 do~nich¾ se lze z~$x$ dostat po~modrých hranách. Nyní mohou nastat dvì mo¾nosti:
170
171 \itemize\ibull
172 \:$y \in M$ (tj. existuje modrá cesta z~$x$ do~$y$): Modrá cesta je v~minimální kostøe a k~minimální kostøe
173 neexistují ¾ádné lehké hrany, tak¾e hrana $e$ je nejdra¾¹í na~cyklu tvoøeném modrou cestou a~touto hranou
174 a mohu na ni pou¾ít èervené pravidlo.
175
176 \fig{04.eps}{3cm}
177
178 \:$y \notin M$: Tehdy øez $\delta(M)$ neobsahuje ¾ádné modré hrany a alespoò jednu, která není
179 èervená (konkrétnì hranu~$e$), tak¾e na~tento øez mù¾eme pou¾ít modré pravidlo.
180
181 \fig{05.eps}{3cm}
182
183 \qeditem
184 \endlist
185
186 \s{Dùkaz vìty:}
187 \itemize\ibull
188 \:{\I Zastaví se:} Z~èerveného a modrého lemmatu plyne, ¾e ¾ádnou hranu nikdy nepøebarvíme, pøibude ka¾dým krokem
189   alespoò jedna obarvená hrana, tak¾e se algoritmus zastaví.
190 \:{\I Obarví v¹e:} Pokud existuje alespoò jedna neobarvená hrana, pak podle bezbarvého lemmatu algoritmus pokraèuje.
191 \:{\I Najde modrou MST:} Podle èerveného a modrého lemmatu le¾í v~$T_{min}$ právì modré hrany.
192 \qeditem
193 \endlist
194
195 \s{Poznámka:}
196 Èervené a modré pravidlo jsou v~jistém smyslu duální. Pro rovinné grafy je na~sebe pøevede obyèejná rovinná
197 dualita (staèí si uvìdomit, ¾e kostra duálního grafu je komplement duálu kostry primárního grafu), obecnìji
198 je to dualita mezi matroidy, která prohazuje øezy a cykly.
199
200 \h{Klasické algoritmy na hledání MST}
201
202 \s{Kruskalùv neboli Hladový:\foot{\rm Mo¾ná hladový s~malým `h', ale tento algoritmus je pradìdeèkem
203 v¹ech ostatních hladových algoritmù, tak mu tu èest pøejme.}}
204
205 \algo
206 \:Setøídíme hrany podle vah vzestupnì.
207 \:Zaèneme s~prázdnou kostrou (ka¾dý vrchol je v~samostatné komponentì souvislosti).
208 \:Bereme hrany ve vzestupném poøadí.
209 \::Pro ka¾dou hranu $e$ se podíváme, zda spojuje dvì rùzné komponenty -- pokud ano, pøidáme ji do~kostry,
210    jinak ji zahodíme.
211 \endalgo
212
213 Èervenomodrý pohled: pìstujeme modrý les. Pokud hrana spojuje dva stromeèky, je~urèitì minimální v~øezu mezi
214 jedním ze~stromeèkù a zbytkem grafu (ostatní hrany tého¾ øezu jsme je¹tì nezpracovali). Pokud nespojuje,
215 je maximální na~nìjakém cyklu tvoøeném touto hranou a nìjakými døíve pøidanými.
216
217 Potøebujeme èas $\O(m \log n)$ na~setøídìní hran a dále datovou strukturu pro udr¾ování komponent souvislosti
218 (Union-Find Problem), se~kterou provedeme $m$ operací \<Find> a $n$ operací \<Union>. Nejlep¹í známá implementace
219 této struktury dává slo¾itost obou operací $\O(\alpha(n))$ amortizovanì, tak¾e celkovì hladový algoritmus
220 dobìhne v~èase $\O(m \log n + m \alpha(n))$.
221
222 \s{Borùvkùv:}
223
224 Opìt si budeme pìstovat modrý les, av¹ak tentokrát jej budeme roz¹iøovat ve fázích. V~jedné fázi nalezneme ke ka¾dému stromeèku nejlevnìj¹í incidentní hranu
225 a v¹echny tyto nalezené hrany naráz pøidáme (aplikujeme nìkolik modrých pravidel najednou). Pokud jsou v¹echny váhy rùzné, cyklus
226 tím nevznikne.
227
228 Poèet stromeèku klesá exponenciálnì $\Rightarrow$ fází je celkem $\log n$. Pokud ka¾dou fázi
229 implementujeme lineárním prùchodem celého grafu, dostaneme slo¾itost $\O(m\log n)$.
230 Mimo to lze ka¾dou fázi výteènì paralelizovat.
231
232 \s{Jarníkùv:}
233
234 Jarníkùv algoritmus je podobný Borùvkovi, ale s tím rozdílem, ¾e nenecháme rùst celý les, ale jen jeden modrý strom. V~ka¾dém
235 okam¾iku nalezneme nejlevnìj¹í hranu vedoucí mezi stromem a zbytkem grafu a pøidáme ji ke~stromu (modré pravidlo);
236 hrany vedoucí uvnitø stromu prùbì¾nì zahazujeme (èervené pravidlo). Kroky opakujeme, dokud se strom nerozroste pøes v¹echny vrcholy.
237 Pøi ¹ikovné implementaci pomocí haldy má èasovou slo¾itost $\O(m\log n)$, v~pøí¹tí kapitole uká¾eme implementaci je¹tì ¹ikovnìj¹í.
238
239 \s{Cvièení:}
240 Naleznìte algoritmus pro výpoèet MST v~grafech ohodnocených vahami $\{1,\ldots k\}$ se slo¾itostí $\O(mk)$.
241
242 \references
243 \bye