Fakulta Informatiky
Masarykova Univerzita
Matematické Základy Informatiky
(FI: IBOOO)
Prof. RNDr. Petr Hliněný, Ph.D.
hlineny@f i.muni.cz 25. listopadu 2014
Obsažný a dobře přístupný úvod do nezbytných formálních matematických základu moderní informatiky, doplněný řadou interaktivních cvičení v IS MU.
Výukový text pro předmět IBOOO na FI MU od roku 2012, navazující zčásti na původní výukové texty Úvodu do Informatiky z minulých let.
Verze 1.9991 (2014)
© 2006-2014 Petr Hliněný, FI MU.
0.1 O tomto textu a jeho studiu
Vážení čtenáři,
dostává se vám do rukou výukový text Matematické Základy Informatiky, který je primárně určený pro studenty stejnojmenného předmětu na FI MU Brno. Seznamuje čtenáře s několika formálními matematickými oblastmi důležitými pro úspěšné studium moderní informatiky.
Náš text svým obsahem volně navazuje na původní slidy předmětu IB000 sepsané A. Kučerou do roku 2005 a rozšířené autorem v letech 2006-11 o volný text a komentáře. Od roku 2012 však byl obsah některých pasáží podstatně změněn či přímo vyměněn za nový (nejzřetelnější je zahrnutí úvodu do grafů). Mimo textu samotného (jak jej zde vidíte) jsou z téhož zdoje vytvářeny i přednáškové slidy předmětu, které najdete například v IS MU. Slidy však pochopitelně obsahují jen část textu a jsou jinak formátovány.
Učební text je psán strukturovaným matematickým přístupem, s velkým důrazem na přesnost a formalitu vyjadřování v nutných partiích. Na druhou stranu jsou strohá matematická vyjádření pokud možno doplněna obsáhlými neformálními komentáři, které mají studentům ulehčit pochopení látky. V žádném případě však čtenáři nemají zaměňovat neformální komentáře za matematické definice - v případě nejasností vždy platí to, co přesně říká formální definice.
Interaktivní osnova
http://is.muni.cz/el/1433/podzim2014/IB000/index.qwarp
Nedílnou součástí celého výukového textu jsou interaktivní osnova předmětu IB000 v IS MU a z ní odkazované online odpovědníky sloužící k procvičování probrané látky na jednoduchých i složitějších příkladech. To je také důvod, proč tento text obsahuje jen poskrovnu řešených příkladů k probírané látce; od každého studenta očekáváme, že si látku bude procvičovat online na zmíněných odpovědnících, obsahujících až tisíce příkladů desítek typů. K praktickému pochopení přednesených znalostí i k jejich budoucím aplikacím je takové procvičení nezbytné(l). V návaznosti na tyto odpovědníky doporučujeme studentům diskutovat o probírané látce a svých (ne)úspěších s cvičícími předmětu i na předmětovém diskuzním fóru v IS.
ii
Obsah
0.1 O tomto textu a jeho studiu......................... ii
1 Základní formalismy matematiky 1
1.1 Úvod do matematického dokazovaní..................... 1
1.2 Význam matematických vět......................... 2
1.3 Struktura matematických vět a důkazů................... 3
1.4 Výroky a základ logiky............................ 5
1.5 Střípky matematické logiky ......................... 7
2 Důkazové techniky, Indukce 12
2.1 Přehled základních důkazových technik................... 12
2.2 Věty typu „tehdy a jen tehdy"........................ 14
2.3 Matematická indukce............................. 15
2.4 Komentáře k matematické indukci...................... 17
3 Množiny, množinové operace 20
3.1 Pojem množiny................................ 20
3.2 Množinové operace.............................. 21
3.3 Porovnávání a určení množin ........................ 24
3.4 Posloupnosti a rekurentní vztahy...................... 26
4 Relace a jejich použití 28
4.1 Relace a funkce nad množinami....................... 28
4.2 Reprezentace konečných relací........................ 30
4.3 Vlastnosti binárních relací.......................... 31
4.4 Inverzní relace a skládání relací....................... 33
4.5 Skládání relací „v praxi"........................... 34
5 Ekvivalence, Uspořádané množiny 37
5.1 Relace ekvivalence .............................. 37
5.2 Rozklady a jejich vztah k ekvivalencím................... 38
5.3 Uspořádání a uspořádané množiny ..................... 39
5.4 Další pojmy uspořádaných množin ..................... 41
5.5 Relace předuspořádání............................ 44
6 Funkce a skládání, Induktivní definice 46
6.1 Vlastnosti funkcí............................... 46
6.2 Skládání funkcí, permutace.......................... 47
6.3 Induktivní definice množin a funkcí..................... 49
6.4 Uzávěry relací................................. 52
7 Pojem grafu, ve zkratce 55
7.1 Definice grafu................................. 55
7.2 Podgrafy a Isomorfismus........................... 58
7.3 Souvislost grafů, komponenty........................ 61
7.4 Stromy - grafy bez kružnic.......................... 63
7.5 Použití a implementace grafů ........................ 64
iii
8 Procházení grafu a odvozené úlohy 67
8.1 Jak obecně projít souvislý graf........................ 67
8.2 Vzdálenost v grafu.............................. 70
8.3 Hledání nejkratší cesty............................ 71
8.4 Problém minimální kostry.......................... 74
9 Orientované grafy, Toky v sítích 78
9.1 Základní pojmy orientovaných grafů..................... 78
9.2 Definice sítě a toku.............................. 81
9.3 Nalezení maximálního toku ......................... 82
9.4 Zobecněné použití sítí ............................ 86
10 Formalizace a důkazy pro algoritmy 90
10.1 Formální popis algoritmu........................... 90
10.2 O „správnosti" a dokazování programů................... 92
10.3 Jednoduché indukční dokazování ...................... 93
10.4 Rekurzivní algoritmy............................. 94
11 Pokročilé dokazování nad algoritmy 97
11.1 Dokazování konečnosti algoritmu ...................... 97
11.2 Přehled technik důkazu indukcí....................... 100
11.3 Zajímavé algoritmy aritmetiky........................ 103
11.4 Dynamický algoritmus............................ 105
12 Nekonečné množiny, Zastavení algoritmu 107
12.1 O nekonečných množinách a kardinalitě................... 107
12.2 „Naivní" množinové paradoxy........................ 109
12.3 Algoritmická neřešitelnost problému zastavení............... 111
i v
1 Základní formalismy matematiky
Úvod
Začneme nejprve několika obecnými poznámkami ke smyslu a směřování celého našeho předmětu: Jak sami poznáte, studium informatiky neznamená jen „naučit se nějaký programovací jazyk", nýbrž zahrnuje celý soubor dalších relevantních předmětů, mezi nimiž najdeme i matematicko-teoretické (formální) základy moderní informatiky Právě odborný nadhled nad celou informatikou včetně nezbytné formální teorie nejspíše odliší „řadového programátora", kterých jsou dnes spousty i bez VS vzdělání, od skutečného a mnohem lépe placeného počítačového experta.
A na tomto místě nyní přichází náš předmět Matematické Základy Informatiky, který vás právě na studium těchto formálních základů moderní informatiky připraví. Výklad začínáme poněkud zostra - zdůrazněním přesného matematického vyjadřování, výrokovou logikou a principy logických úsudků a matematických důkazů. Nelekejte se však hned a s chutí se dejte do studia, nebude to až tak obtížné. ..
Cíle
Prvním cílem této lekce je rozebrat struktury matematických tvrzení (vět) a jejich formálních důkazů. V druhém sledu se naučíte chápat smysl matematických vět formálním pohledem výrokové logiky a pracovat s touto formalizací, včetně kvantiňkace.
1.1 Úvod do matematického dokazování
Matematika (a tudíž i teoretická informatika jako její součást) se vyznačuje velmi přísnými formálními požadavky na korektnost argumentace. Takto korektně postavená argumentace vede od přijatých předpokladů v elementárních krocích směrem k požadovanému závěru (a nikdy ne naopak!).
Definice 1.1. Matematický důkaz .
Uvažme matematickou větu (neboli tvrzení) tvaru
„Jestliže platí předpoklady, pak platí závěr". Důkaz této věty je konečná posloupnost tvrzení, kde
• každé tvrzení je buď
* předpoklad, nebo
* obecně přijatá „pravda" - axiom, nebo
* plyne z předchozích a dříve dokázaných tvrzení podle nějakého „akceptovaného" logického principu - odvozovacího pravidla:
• poslední tvrzení je závěr.
Komentář: O potřebné úrovni formality matematických důkazů a o běžných důkazových technikách se dozvíme dále v této a příští lekci. Nyní si jen celou problematiku uvedeme názornými příklady.
Příklad 1.2. Uvažujme následující matematické tvrzení (které jistě už znáte). Věta. Jestliže x je součtem dvou lichých čísel, pak x je sudé.
1
Poznámka pro připomenutí:
- Sudé číslo je celé číslo dělitelné 2, tj. tvaru 2k.
- Liché číslo je celé číslo nedělitelné 2, tj. tvaru 2k + 1.
Důkaz postupuje v následujících formálních krocích: tvrzení zdůvodnění
1) a = 2k + 1, k celé předpoklad
2) b = 21 + 1, / celé předpoklad
3) x = a + b = 2k + 21 + 1 + 1 1,2) a komutativita sčítání (axiom)
4) x = 2(k + /) + 2 • 1 3) a distributivnost násobení
5) x = 2(k + / + 1) 4) a opět distributivnost násobení
6) x = 2m, m celé 5) a m = k + / + 1 je celé číslo (axiom)
Příklad 1.3. Dokažte následující tvrzení:
Věta. Jestliže x a y jsou racionální čísla pro která platí x < y, pak existuje racionální číslo z pro které platí x < z < y.
Důkaz po krocích (s již trochu méně formálním zápisem) zní:
1) Nechť z = =x + ^ =y-
2) Číslo z je racionální, neboť x a, y jsou racionální.
3) Platí z > x, neboť ^ > 0.
4) Dále platí z < y, neboť opět > 0.
5) Celkem x < z < y.
Jak čtenář vidí, tento strohý formální zápis (i když matematicky kompletní) si zaslouží aspoň krátký vysvětlující komentář. Takový komentář, ať už se objeví před nebo hned po formálních argumentech, sice není součástí důkazu samotného, velmi však napomáhá správnému pochopení a má své nezastupitelné místo. Konkrétně je zde velmi vhodné poznamenat, že klíčový krok (1) popisuje námi vymyšlenou algebraickou konstrukci, která vede k požadovanému číslu z. Zbylé kroky (2-5) pak jen snadno zdůvodňují, že nalezené z má všechny požadované vlastnosti. □
Poznámka. Alternativní formulace Věty z Příkladu 1.3 mohou znít:
- Pro každé x, y G Q, kde x < y, existuje z G Q takové, že x < z < y.
- Množina racionálních čísel je hustá.
1.2 Význam matematických vět
První krok formálního důkazu je uvědomit si, co říká věta, která se má dokázat; tedy co je předpoklad a co závěr dokazovaného tvrzení. Pravdivost takového tvrzení pak je třeba
2
chápat v následujícím významu:
Pro každou situaci, ve které jsou splněny všechny předpoklady, je platný i závěr tvrzení.
Komentář: Příklady běžné formulace matematických vět:
* Konečná množina má konečně mnoho podmnožin.
* sin2(a) + cos2(a) = 1.
* Graf je rovinný, jestliže neobsahuje podrozdělení K5 nebo 1^3,3.
Co přesně nám uvedené matematické věty říkají? Často nám k lepšímu pochopení toho, co je tvrzeno a je třeba dokázat, pomůže pouhé rozepsání definic pojmů, které se v dané větě vyskytují.
O pravdivosti implikace
Všimněte si také, jaký je správný logický význam matematického tvrzení vysloveného touto formou implikace („jestliže ..., pak ... "). Především, pokud předpoklady nejsou splněny nebo jsou sporné, tak celé tvrzení je platné bez ohledu na pravdivost závěru!
Příklad 1.4. Je pravdivé následující matematické tvrzení?
Věta. Mějme dvě kuličky, červenou a modrou. Jestliže červená kulička je těžší než modrá a zároveň je modrá kulička těžší než ta červená, tak jsou obě kuličky ve skutečnosti zelené.
„ To přece nemůže být pravda, jak může být jedna kulička těžší než druhá a naopak zároveň? Jak mohou být nakonec obě zelené? To je celé nějaká blbost... "
Ano, výše uvedené jsou typické laické reakce na uvedenou větu. Přesto však tato věta pravdivá je! Stačí se vrátit o kousek výše ke kritériu - Pro každou situaci, ve které jsou splněny všechny předpoklady je platný i závěr tvrzení - které je zjevně naplněno. Nenaleznete totiž situaci, ve které by byly splněny oba předpoklady zároveň, a tudíž ve všech takových neexistujících situacích si můžete říkat cokoliv, třeba že kuličky jsou zelené. □
Příklad 1.5. Anna a Klára přišly na přednášku a usadily se do lavic. Proč je pravdivé toto matematické tvrzení?
Věta. Jestliže Anna sedí v první řadě lavic a zároveň Anna sedí v poslední řadě lavic, tak Klára nesedí v druhé řadě lavic.
Opět je třeba se hluboce zamyslet nad významem předpokladů a závěru, ale tentokrát není situace předpokladů tak triviálně sporná, jako v Příkladu 1.4. Kdy tedy nastávají oba předpoklady zároveň? Když první řada lavic je zároveň řadou poslední! Neboli posluchárna má jen (nejvýše) jednu řadu lavic a Klára tudíž v druhé řadě nemůže sedět. Důkaz je hotov. □
1.3 Struktura matematických vět a důkazů
Jak „moc formálníCÍ mají správné matematické důkazy vlastně být?
3
• Záleží na tom, komu je důkaz určen — konzument musí být schopen „snadno" ověřit korektnost každého tvrzení v důkazu a plně pochopit, z čeho vyplývá.
• Je tedy hlavně na vás zvolit tu správnou úroveň formálnosti zápisu vět i důkazů podle situace.
A jak na ten správný matematický důkaz máme přijít?
• No..., nalézání matematických důkazů je tvůrčí činnost, která není vůbec snadná a vyžaduje od vás přímo „umělecké" vlohy. Přesto se jí alespoň trochu musíte přiučit.
Dokazovat či vyvracet tvrzení?
Představme si, že našim úkolem je rozhodnout platnost matematického tvrzení. Jak matematicky správně zdůvodníme svou odpověď?
• Záleží na odpovědi samotné... Pokud je to ANO, prostě podáme důkaz tvrzení podle výše uvedených zvyklostí. Pokud je odpověď NE, tak naopak podáme důkaz negace daného tvrzení.
Poměrně častým případem pak je matematická věta T, která tvrdí nějaký závěr pro širokou oblast vstupních možností. Potom platí následující:
• Pokud T je pravdivá, nezbývá než podat vyčerpávající důkaz platnosti pro všechny vstupy.
• Avšak pokud T je nepravdivá, stačí „uhodnout" vhodný vstupní protipříklad a jen pro něj dokázat, že závěr tvrzení není platný.
Komentář: A nyní se znovu vraťte na začátek Oddílu 1.2 a srovnejte si výše uvedené se základními poznatky o významu matematických vět...
Příklad 1.6. Rozhodněte platnost následujícího tvrzení: Pro všechna reálná x platí
x2 + 3x + 2 > 0 .
Důkaz: Standardními algebraickými postupy si můžeme upravit vztah na x2 + 3x + 2 = (x + 1) • {x + 2) > 0. Co nám z něj vyplývá? Například to, že k porušení daného tvrzení stačí volit x tak, aby jedna ze závorek byla kladná a druhá záporná. To nastane třeba pro x = — |.
Pro vyvrácení tvrzení nám tedy stačí začít volbou protipříkladu x = — | (není nutno zdůvodňovat, jak jsme jej „uhodli"!) a následně dokázat úpravou
x2+ 3x + 2 = (x + l).(x + 2) = (-| + l).(-|+2) = (-!)•(+!) = ~<0. Dané tvrzení není platné. □
Konstruktivní a existenční důkazy
Z hlediska praktické využitelnosti je potřeba rozlišit tyto dvě kategorie důkazů (třebaže z formálně-matematického pohledu mezi nimi kvalitativní rozdíl není).
• Důkaz Věty 1.3 je konstruktivní. Dokázali jsme nejen, že číslo z existuje, ale podali jsme také návod, jak ho pro dané x a y sestrojit.
4
• Existenční důkaz je takový, kde se prokáže existence nějakého objektu bez toho, aby byl podán použitelný návod na jeho konstrukci.
Příklad 1.7. čistě existenčního důkazu.
Věta. Existuje program, který vypíše na obrazovku čísla tažená ve 45. tahu sportky v roce 2014.
Důkaz: Existuje pouze konečně mnoho možných výsledků losování 45. tahu sportky v roce 2014. Pro každý možný výsledek existuje program, který tento daný výsledek vypíše na obrazovku. Mezi těmito programy je tedy jistě ten, který vypíše právě ten výsledek, který bude ve 45. tahu sportky v roce 2014 skutečně vylosován.
□
Komentář: To je ale „podvod", že? A přece není... Formálně správně to je prostě tak a tečka (2011: tedy dokud nám to pan Husák všechno nepokazí, že?).
Fakt. Pro informatické i další aplikované disciplíny je důležitá konstruktivnost důkazů vět, které se zde objevují. V matematice ale jsou mnohé příklady užitečných a nenahraditelných existenčních důkazů, třeba tzv. pravděpodobnostní důkazy.
Příklad 1.8. „pravděpodobnostního" existenčního důkazu.
Věta. Na dané množině bodů je zvoleno libovolně n2 podmnožin, každá o n prvcích. Dokažte pro dostatečně velká n, že všechny body lze obarvit dvěma barvami tak, aby žádná množina nebyla jednobarevná.
Důkaz: U každého bodu si „hodíme mincí" a podle výsledku zvolíme barvu červeně nebo modře. (Nezávislé volby s pravděpodobností |.) Pravděpodobnost, že zvolených n bodů vyjde jednobarevných, je jen ^ = 21_n.
Pro n2 podmnožin tak je pravděpodobnost, že některá z nich vyjde jednobarevná, shora ohraničená součtem
-> 0.
Jelikož je toto číslo (pravděpodobnost) pro n > 7 menší než 1, bude existovat obarvení bez jednobarevných zvolených podmnožin. □
1.4 Výroky a základ logiky
Pojem výroku se dá považovat za důležitý „pevný most" mezi běžnou mluvou a přesným matematickým formalismem. Jeho správné uchopení napomůže chápání významu matematických výroků a práci s nimi (jako třeba v případě mechanické negace složeného výroku).
Definice 1.9. Výrok v přirozené mluvě:
V běžné mluvě za výrok považujeme (každé) tvrzení, o kterém má smysl platně prohlásit, že je buď pravdivé nebo nepravdivé.
Komentář: Ukážeme si několik příkladů - které z nich jsou výroky?
* Dnes už v Brně pršelo.
* Předmět FI: IB000 se vyučuje v prvním ročníku.
* Platí 2 + 3 = 6.
5
* To je bez problémů. (Co?)
* Platí x > 3.
* Pro každé celé číslo x platí, že x > 3.
Všimněte si, že pravdivost výroku by mělo být možné rozhodnout bez skrytých souvislostí (kontextu), a proto čtvrtý a pátý příklad za výroky nepovažujeme. Poslední příklad již zase výrokem je, neboť obor hodnot x je jednoznačně vymezen tzv. kvantifikací.
Z více jednoduchých výroků vytváříme výroky složitější pomocí tzv. logických spojek.
Komentář: Následuje několik dalších příkladů.
* Množina {a, b} má více než jeden prvek a není nekonečná.
* Jestliže má Karel přes 90 kg váhy, nejedu s ním výtahem.
* Jestliže má tato kráva 10 nohou, pak mají všechny domy modrou střechu. Zastavme se na chvíli nad posledním výrokem. Co nám říká? Je pravdivý? Skutečně mají všechny domy modrou střechu a před námi stojí kráva s 10 nohama? (Ano, výrok je pravdivý, viz definice či pravdivostní tabulka implikace.)
Schopnost porozumět podobným větám je součást lidského způsobu uvažování a z tohoto hlediska nemá přímou souvislost s matematikou (je to „přirozená logika"). Formální (matematická) logika pak v podobném duchu definuje jazyk matematiky a přitom odstraňuje nejednoznačnosti přirozeného jazyka.
Ukázka formální práce s výroky
Pro příklad důležitosti matematické formalizace slovních výroků si rozebereme následující logickou „hádanku", navazující na téma Příkladu 1.5.
Příklad 1.10. Mějme trojici studentů X,Y,Z sedících v posluchárně na přednášce IB000 takových, že pro ně platí:
a) X sedí v první řadě,
b) Y sedí v řadě hned za X,
c) Z sedí ve stejné řadě jako Y,
d) Z sedí ve druhé řadě.
Věta. Jestliže zároveň platí (a),(b),(c),(d), pak student Z sedí ve druhé řadě.
Tvrzení je samozřejmě triviální díky předpokladu (d), avšak úkolem je zjistit, jaké všechny minimální výběry z předpokladů (a),(b),(c),(d) ještě zajistí platnost uvedeného tvrzení.
Pro začátek osvětlíme (blíže viz Oddíl 5.4) význam slova minimální, kdy je myšlen výběr předpokladů takový, že odebráním libovolného z nich již platnost uvedeného tvrzení „Z sedí ve druhé řadě" bude porušena.
Okamžitou odpovědí je samotný předpoklad (d), který je zřejmě minimální (bez předpokladů si může Z sednout i do první řady) a dostačující. Je to však úplná odpověď, nebo lze vybrat i jiné minimální předpoklady? Ano, ještě lze vybírat jinak - po vynechání (d) stále postačuje kombinace předpokladů (a),(b),(c) k vyslovení závěru „Z sedí ve druhé řadě" (je to jasné?). Na druhou stranu, pokud kterýkoliv z (a),(b),(c) vynecháme, rozebráním těchto tří možností najdeme platná rozesazení, při kterých Z v druhé řadě nebude, takže se opět jedná o výběr minimální. Například pokud vynecháme (b), může Y sedět v první řadě spolu s V a stejně tak Z. Dořešte si sami zbylé dvě možnosti.
6
Pozor, ještě k úplnému vyřešení úlohy zbývá poslední důležitý krok - zdůvodnit, proč žádný jiný minimální výběr předpokladů úloze nevyhovuje. Zde je třeba rozebrat možnosti: Pokud náš hypotetický jiný výběr předpokladů obsahuje (d), pak nebude minimální, neboť lze odebrat cokoliv jiného, pokud (d) zůstane. Naopak výběr neobsahující (d) musí podle výše uvedeného obsahovat všechny (a),(b),(c), neboť jinak není dostačující. A tím jsme hotovi; všechny minimální výběry řešící úlohu jsou dva, (a),(b),(c) a samotné (d). □
1.5 Střípky matematické logiky
Všimněte si, že podle Definice 1.9 každému výroku běžné mluvy prostě můžeme přiřadit logickou hodnotu 0 (falše) nebo 1 (true) a dále se nestarat o jazykový význam... Proto (jazykové) výroky v matematice vyjádříme výrokovými proměnnými, které značíme velkými písmeny A, B,C,... a přiřadíme jim hodnotu 0 nebo 1.
Definice: Výroková formule (značíme
, o, ip,...) vzniká z výrokových proměnných pomocí závorek a logických spojek -i negace a =>- implikace. Zároveň používáme v zápise následujících zkratek
* ip\/ ip (disjunkce/„nebo") je jiný zápis formule ~np =>- ip,
*
A ip (konjunkce/„a") je jiný zápis formule —<(—np\J— <=ř ip (ekvivalence) je jiný zápis formule (ip =>- ip) A (ip =>• ip).
Poznámka: Uvedená definice je instancí tzv. induktivní deňnice, jíž se budeme blíže věnovat v Oddíle 6.3, a proto ji zde uvádíme jen v hodně zjednodušené podobě.
Komentář: Při zápise výrokových formulí je potřeba dávat pozor na správné závorkování, aby formule měla jednoznačný význam. Na intuitivní úrovni to ilustrujeme takto:
a nesprávně A =ř B =ř C — znamená to (A => B) => C nebo A => (B => C)? Matematický význam logickým formulím pak dodává následující definice.
Definice 1.11. Sémantika (význam) výrokové logiky.
Nechť valuace (ohodnocení) je funkce v : Prom —> {0,1} na všech (dotčených) výrokových proměnných. Pro každou valuaci v definujeme funkci Sv(o), vyhodnocení formule a, induktivně (tj. po krocích) takto:
* Sjy(A) = v(A) pro každé A G Prom.
Poznámka: Tento předpis podává nejen deňnici funkce Sv, ale také návod na to, jak ji pro daný argument vypočítat.
Pro odvozené logické spojky disjunkce, konjunkce a ekvivalence pak dostaneme následující zcela přirozený výsledek (který tak potvrzuje, že jsme definici sémantiky zvolili správně).
Správně
A, (A)=>(B), A^B, ^A^B, AVBV^C
0 jestliže Sv(ip) = 1 a Sv(ip) = 0:
7
Tvrzení 1.12. Důsledkem Definice 1.11 je následovné:
* Sv{ip V ip) = 1 právě když Sv( B)\/ B V C?
A B c A ^B (A B) V 5 V C
0 0 0 1 1
0 1 0 1 1
1 0 0 0 0
1 1 0 1 1
0 0 1 1 1
0 1 1 1 1
1 0 1 0 1
1 1 1 1 1
Splnitelnost formulí a tautologie
Definice: Formule p> G $ je splnitelná, pokud pro některou valuaci z/ platí, že Sv(íp) = 1. Formule je nesplnitelná (říká se také kontradikce), pokud není splnitelná. Formule p> G <& je vždy pravdivá, neboli výroková tautologie, psáno |= p>, pokud pro každou valuaci v platí, že Sv{ip) = 1.
Řekneme, že dvě formule p>,ip G $ jsou ekvivalentní, právě když |= p> ip.
Tvrzení 1.14. Následující formule jsou tautologiemi: A V —i^4
(A A (i 4- 5)) 5 (-.£ ^ (A =^ 5)
(-.A 4 (BA -.£)) 4 Komentář: Jak poznáme tautologii v pravdivostní tabulce?
8
Kvantifikace a predikátová logika
Výše popsaná výroková logika je velmi omezená faktem, že každý výrok musí být („absolutně") vyhodnocen jako pravda nebo nepravda. Co když však chceme zpracovat tvrzení typu „den D v Brně pršelo"? Jeho pravdivostní hodnota přece závisí na tom, co dosadíme za den D, a tudíž jej nelze považovat za výrok výrokové logiky.
• Predikátová logika pracuje s predikáty. Predikáty jsou „parametrizované výroky", které jsou buď pravdivé nebo nepravdivé pro každou konkrétní volbu parametrů. Výrokové proměnné lze chápat jako predikáty bez parametrů.
• Predikátová logika je tak obecnější než logika výroková; každá formule výrokové logiky je i formulí predikátové logiky, ale ne obráceně.
Komentář: Pro neformální přiblížení si uvedeme několik ukázek predikátů:
* x > 3 (parametrem je zde iěr),
* čísla x a y jsou nesoudělná (parametry x, y £ N).
* obecně jsou predikáty psány P(x,y), kde x,y jsou libovolné parametry.
Definice: Z predikátů lze vytvářet predikátové formule pomocí už známých (viz Definice 1.11) výrokových spojek a následujících tzv. kvantifikátorů:
• \/x. ip „pro každou volbu parametru x platí formule 99",
• 3x . ip „existuje alespoň jedna volba parametru x, pro kterou platí 99".
Komentář: Pozorného čtenáře napadne, ze které množiny že „volíme parametr x"? To je v matematické logice obvykle implicitní (řečeno mimo samotnou formuli) a platí pro všechny kvantifikátory formule stejně. Může to být sice trochu v rozporu s tím, co jste se možná učili dříve, ale má to dobré formální důvody.
Čtenář by měl v tomto místě vzít na vědomí, že naše definice vztahující se k predikátové logice jsou velmi zjednodušené a nenahrazují kurz matematické logiky! Přesto poskytnou alespoň základní povědomí o této problematice (a hlavně o použití kvantifikace v tvrzeních) pro potřeby matematické formalizace v našem kurzu.
Fakt: Jedi každá proměnná - parametr predikátu - v dané formuli kvantifikovaná (tj. formule je uzavřená), pak je celá formule buď pravdivá nebo nepravdivá.
Příklad 1.15. Ukažme si vyjádření následujících slovních výroků v predikátové logice:
• Každé prvočíslo větší než 2 je liché:
vííén. [(Pr(n)An>2) Li(n)],
přičemž lze rozepsat Li(n) = 3fcGN. n = 2k + 1.
• Každé číslo n > 1, které není prvočíslem, je dělitelné nějakým číslem y kde n/i/a
y > i;
VnGN. (n > 1 A -iPr(n)) =>- 3y(y\n A n^y A y>l). Poznámka: Pozor, v tomto předmětu počítáme 0 za přirozené číslo]
9
Příklad 1.16. Dále si ukažme, že na pořadí kvantifíkátorů velmi záleží:
• Pro každého studenta A v posluchárně platí, že existuje student B v posluchárně takový, že A je kamarád B.
• Existuje student B v posluchárně, že pro každého studenta A v posluchárně platí, že A je kamarád B.
Vidíte propastný rozdíl ve významech uvedených dvou uzavřených predikátových formulí? □
Mechanický postup negace výroků
Závěrem lekce se dostáváme k jednomu specifickému úskalí lidského chápání, totiž že přesný význam formulí se zanořenými negacemi je někdy skutečně obtížné zjistit (podobně jako v běžné řeči).
„ Není pravda, že nemohu neříci, že není pravda, že tě nemám nerad."
Výrokové formule se proto obvykle prezentují v tzv. normálním tvaru, kde se negace vyskytují pouze u výrokových proměnných, formálně:
Definice: Formule ip G $ je v normálním tvaru, pokud se v ní operátor negace aplikuje pouze na výrokové proměnné.
Komentář: Například, pokud přijmeme pravidlo „dvojí negace" (|= -i —*A 4^ A), tak výše napsanou větu si převedeme na lépe srozumitelný tvar:
„Nemusím říct, že tě mám nerad."
Tvrzení 1.17. Každou výrokovou formulí lze převést do normálního tvaru, pokud k =>• povolíme i užívání odvozených spojek A a V.
Komentář: Pro ilustraci k -<(A =4> B) je ekvivalentní A A - -B)) je ekvivalentní ->C V (->A A ->B) a k ->((A B) C) je ekvivalentní (A B) A ->C).
Metoda 1.18. Převod formule ip do normálního tvaru ÍF((p).
Pro převod použijeme funktory T a Q s neformálním významem F(X) jako „je pravda, že X" a Q{X) jako „nenípravda, že X". Tyto funktory definujeme induktivními předpisy následovně:
F {A) = A g{A) = ^A
F(íP^Íj) = f(
) G(ip^ij) = (J(ríA^))V(%)A^))
Pro predikátové formule toto rozšíříme ještě o pravidla:
F(Vx.ip) = Vx.F(ip) G(Vx.ip) = 3x.g(ip)
F(3x.(p) = 3x.Jľ((p) Q(3x. (p) = \/x.Q(ip)
10
Komentář: Uvažme formuli —<(A =4> ~^{B V _,(C =4> —iA))). Užitím uvedeného postupu 1.18 získáme:
F(->(A => ->(B V -i(C => - -*A))) =
J(i)Ag(n(BV-(C^^))) = AA7(BVn(C=>nA)) AA(J(B)V7(n(C=>nA))) = AA(5V6(C^^)) AA(BV(J(C)A5(nA))) = AA(BV(CAJ(A)))
AA(BV(CAA))
Formuli A A (-B V (C A A)) lze dále zjednodušit na (ekvivalentní) formuli A A {B V C). To ale je již z našeho pohledu matematicky neformální (heuristický) postup.
Uvedené formální předpisy takto vyjadřují intuitivní postup převodu ÍF((p) do „lidsky čitelného tvaru".
Navazující studium
Látka této úvodní lekce má velmi široký záběr. S potřebou formálního zápisu tvrzení a důkazů se setkáte nejen v tomto, ale i ve všech dalších matematických předmětech, které zároveň studujete či budete studovat, a principy budou stále stejné. Proto se je snažte pochopit a zažít už na zde uvedených jednoduchých příkladech a vše si procvičte. A pokud vám stále „jde hlava kolem" z logického matematického vyjadřování, můžete se také zkusit podívat na hezkou úvodní (středoškolskou) knížku Antonína Sochora - Logika pro všechny ochotné myslet, Karolinum 2011.
Na druhou stranu je matematická logika v této lekci uvedena jen velmi omezeně na nejlehčí akceptovatelné intuitivní úrovni a její další rozvoj je ponechán samostatným kurzům. Na FI MU to bude navazující předmět IB101 Úvod do logiky. Zájemce o studium matematických hlubin logiky a třeba slavných Gódelových poznatků můžeme později odkázat na předmět MA007 Matematická logika.
11
2 Důkazové techniky, Indukce
Úvod
Náš hlubší úvod do matematických formalismů pro informatiku pokračujeme základním přehledem technik matematických důkazů. Třebaže matematické dokazování a příslušné techniky mohou někomu připadat neprůhledné (a možná zbytečné), jejich pochopení a zvládnutí není samoúčelné, neboť nám pomáhá si mnoho uvědomit o studovaných problémech samotných. Konečně, jak si můžeme být jisti svými poznatky, když bychom pro ně nebyli schopni poskytnout důkazy?
Během studia tohoto předmětu poznáte (a ti méně šťastní až s překvapením u zkoušek), že podstata toho, k čemu naším výkladem směřujeme, se dá neformálně shrnout slovy „naučit se přesně vyjadřovat a být si svými tvrzeními naprosto jisti" a analogicky později „naučit se navrhovat správné algoritmy a být si i svými programy naprosto jisti".
Z důkazových postupů je pro informatiky asi nejdůležitější technika důkazů matematickou indukcí, která je svou podstatou velmi blízká počítačovým programům (coby iterace cyklů). V dalším výkladu budeme indukci hojně využívat, především v Lekcích 10 a 11.
Cíle
Cílem této lekce je popsat základní techniky matematických důkazů, z nichž největší důraz klademe na matematickou indukci. Každý student by se měl alespoň naučit formálně psané důkazy číst a pochopit. (Pro vysvětlení, z Lekce 1 víme, že matematický důkaz má „jednotnou formu" Deňnice 1.1, ale nyní se věnujeme takříkajíc šablonám, podle nichž takový korektní důkaz sestavíme.)
2.1 Přehled základních důkazových technik
V matematice je často používaných několik následujících způsobů - technik, jak k danému tvrzení nalézt korektní formální důkaz. (Uvědomme si, že jedno tvrzení mívá mnoho různých, stejně korektních, důkazů; ty se však mohou výrazně lišit svou složitostí.) Tyto techniky si v bodech shrneme zde:
• Přímé odvození. To je způsob, o kterém jsme se dosud bavili.
Postupujeme přímo od předpokladů k závěru, ale sami poznáte, že taková „přímá" cesta je obtížně k nalezení.
• Kontmpozíce (také obrácením či nepřímý důkaz). Místo věty
„Jestliže platí předpoklady, pak platí závěr." budeme dokazovat ekvivalentní větu
„Jestliže neplatí závěr, pak neplatí alespoň jeden z předpokladů."
• Důkaz sporem. Místo věty
„Jestliže platí předpoklady, pak platí závěr." budeme dokazovat větu
„Jestliže platí předpoklady a platí opak závěru, pak platí"
- nějaké zjevně nepravdivé tvrzení, nebo případně
- opak závěru či opak jednoho z předpokladů.
12
• Matematická ináukce. Pokročilá technika, kterou popíšeme později... Tyto techniky jsou asi nejlépe ilustrovány následovnými příklady důkazů.
Příklad důkazu kontrapozicí
Definice: Prvočíslo je celé číslo p > 1 a nemá jiné dělitele než lap.
Příklad 2.1. Na důkaz kontrapozicí (obrácením).
Věta. Jestliže p je prvočíslo větší než 2, pak p je liché. Důkaz: Obráceného tvrzení - budeme tedy dokazovat, že
je-li p sudé, pak p buď není větší než 2, nebo p není prvočíslo.
Připomínáme, že podle definice je p sudé, právě když lze psát p = 2 • k, kde k je celé. Jsou dvě možnosti:
• k < 1. Pak p = 2k není větší než 2.
. k > 1. Pak p = 2 • k není prvočíslo podle definice. ^
Poznámka: Důkazy kontrapozicí pracují s negací (opakem) předpokladů a závěru. Je-li např. závěrem komplikované tvrzení tvaru
„z toho, že z A a B plyne C, vyplývá, že z A nebo C plyne A a Bíl,
není pouhou intuicí snadné zjistit, co je vlastně jeho negací. Proto se nebojte využívat snadného mechanického postupu Metody 1.18 ke správnému „znegovaní" do normálního tvaru.
Příklady důkazu sporem
Příklad 2.2. Jiný přístup k Důkazu 2.1.
Věta. Jestliže p je prvočíslo větší než 2, pak p je liché.
Důkaz sporem: Nechť tedy p je prvočíslo větší než 2, které je sudé. Pak p = 2 ■ k pro nějaké k > 1, tedy p není prvočíslo, spor (s předpokladem, že p je prvočíslo). ^
Důkaz sporem je natolik specifický a důležitý v matematice, že si zaslouží širší vysvětlení. Co je vlastně jeho podstatou? Je to (zcela přirozený) předpoklad, že v konzistentní teorii nelze zároveň odvodit tvrzení i jeho negaci. Jestliže tedy ve schématu
„Jestliže platí předpoklady a platí opak závěru, pak platí opak jednoho z předpokladů, nebo platí jiné zjevně nepravdivé tvrzení."
odvodíme k některému předpokladu jeho spor, nebo případně jiné tvrzení, které odporuje všeobecně přijatým faktům (přesněji axiomům, například 0 = 1), pak něco musí být „špatně". Co však v našem tvrzení může (nezapomeňte předpoklad konzistence) být chybné? Původní předpoklady byly dány, takže zbývá jedině náš dodatečný předpoklad, že platí opak závěru. Tudíž opak závěru nemůže nikdy platit a dvojí negací odvodíme, že platí původní závěr.
Příklad 2.3. Opět sporem.
Věta. Číslo y/2 není racionální.
13
Důkaz sporem: Nechť tedy \f2 je racionální, tj. nechť existují nesoudělná celá kladná čísla r, s taková, že \/2 = r/s.
- Pak 2 = r2/s2, tedy r2 = 2 • s2, proto r2 je dělitelné dvěma. Z toho plyne, že i r je dělitelné dvěma (proč? opět na to můžete jít sporem...).
- Jelikož r je dělitelné dvěma, je r2 dělitelné dokonce čtyřmi, tedy r2 = 4 • m pro nějaké m. Pak ale také 4 • m = 2 • s2, tedy 2 • m = s2 a proto s2 je dělitelné dvěma.
- Z toho plyne, že s je také dělitelné dvěma. Celkem dostáváme, že r i s jsou dělitelné dvěma, jsou tedy soudělná a to je spor (s definicí racionálního čísla). □
Komentář: „Nevíte-li, jak nějakou větu dokázat, zkuste důkaz sporem... "
2.2 Věty typu „tehdy a jen tehdy"
Uvažujme nyní (v matematice poměrně hojné) věty tvaru
„Nechť platí předpoklady P. Pak tvrzení A platí tehdy a jen tehdy, platí-li tvrzení B."
Příklady jiných jazykových formulací téže věty jsou:
* Za předpokladů P je tvrzení B nutnou a postačujícípodmínkou pro platnost tvrzení A.
* Za předpokladů P je tvrzení A nutnou a postačující podmínkou pro platnost tvrzení B.
* Nechť platí předpoklady P. Pak tvrzení A platí právě tehdy když platí tvrzení B.
Fakt: Důkaz vět tohoto tvaru má vždy dvě části(!). Je třeba dokázat:
* Jestliže platí předpoklady P a tvrzení A, pak platí tvrzení B.
* Jestliže platí předpoklady P a tvrzení B, pak platí tvrzení A.
Příklad 2.4. Na důkaz typu „tehdy a jen tehdy".
Věta. Dokažte, že pro každá dvě celá čísla a, b platí, že a < b právě tehdy, když 2a < 2b.
Důkaz: Nezapomínáme, že našim úkolem je dokázat oba směry tvrzení (implikace zleva doprava a zprava doleva). Začneme s prvním: Předpoklad a < b je definičně ekvivalentní tomu, že b = a + k pro nějaké přirozené k > 0. Potom 2b = 2a+k = 2a ■ 2k = £ ■ 2a pro nějaké přirozené í = 2k > 2, a tudíž 2b — 2a = (l — 1) • 2a > 1 • 2a > 0 . Tím je první část důkazu hotova.
V opačném směru postupujeme z předpokladu 2a < 2b. Vydělením obou stran nerovnosti kladným číslem 2a získáme 26/2a = 2b~a > 1. Dále postupujeme sporem. Nechť tedy a > b, neboli a — b = m > 0. Potom máme 2a~b = 2 ■ ... 2, > 1. Avšak celkově
mx
1 = 2° = 2a~b ■ 2b~a > 1 • 1 = 1 je sporné. Proto zbývá požadovaný závěr a < b. □
Komentář: Je možno se někdy oddělenému zpracování obou směrů takového tvrzení vyhnout? Ano, stačí dělat pouze tzv. ekvivalentní úpravy, ale je to velmi nebezpečné. Co například tvrzení „a = b právě když ax = bx"? To přece dokážeme vynásobením obou stran rovnosti stejným číslem x...
14
Je to sice téměř pravda, ale(!) musíme si všimnout, že násobení obou stran rovnosti je ekvivalentní úpravou jen pro i / 0; jinak nazpět dělíme nulou (což na světě dokáže pouze Chuck Norris). Zapamatujte si, že nejlepší cestou, jak se takovým chybám a problémům vyhnout, je skutečně poctivě dokazovat každý směr ekvivalence zvlášť.
2.3 Matematická indukce
Pokud se souhrnně podíváme na důkazové techniky v matematice, všimneme si, že matematická indukce je skoro „dvorní" důkazovou technikou diskrétní matematiky. To proto, že umožňuje pohodlně dokazovat i složitá tvrzení po jednotlivých (diskrétních) krocích od počátečního.
Uvažme tedy větu ve tvaru:
„Pro každé přirozené (celé) n > ko platíT(n).u
Zde k0 je nějaké pevné přir. číslo a T(n) je tvrzení parametrizované čís. n. Příkladem je třeba tvrzení:
Pro každé n > 0 platí, že n přímek dělí rovinu nejvýše na ^n(n + 1) + 1 oblastí.
Definice 2.5. Princip matematické indukce říká, že k důkazu věty
„Pro každé přirozené (celé) n > k$ platíT(n).u stačí ověřit platnost těchto dvou tvrzení:
• T(k0) (tzv. báze neboli základ indukce)
• Pro každé n > k$; jestliže platí T(n), (indukční předpoklad) pak platí také T(n + 1). (indukční krok)
Formálně řečeno, matematická indukce je axiomem aritmetiky přirozených čísel.
Opět jako v předešlém si tuto techniku ilustrujeme množstvím názorných příkladů.
Příklady důkazů indukcí
Příklad 2.6. Velmi jednoduchá a přímočará indukce.
Věta. Pro každé přirozené, n > 1 je stejná pravděpodobnost, že při současném hodu n kostkami bude výsledný součet sudý, jako, že bude lichý.
Důkaz: Základ indukce je zde zřejmý: Na jedné kostce (poctivé!) jsou tři lichá a tři sudá čísla, takže obě skupiny padají se stejnou pravděpodobností.
Indukční krok pro n > 1: Nechť psn pravděpodobnost, že při hodu n kostkami bude výsledný součet sudý, a pln je pravděpodobnost lichého. Podle indukčního předpokladu Je Pn = Pn = \- Hoďme navíc (n + l)-ní kostkou. Podle toho, zda na ní padne liché nebo sudé číslo, je pravděpodobnost celkového sudého součtu rovna
3 ř 3 s 1 ~6Pn + ~6Pn = -2
a stejně pro pravděpodobnost celkového lichého součtu. □ Příklad 2.7. Ukázka skutečné důkazové „síly" principu matematické indukce.
15
Věta. Pro každé n > O platí, že n přímek dělí rovinu nejvýše na 1
-n(n + 1) + 1
oblastí.
Důkaz: Pro bázi indukce stačí, že 0 přímek dělí rovinu na jednu část. (Všimněte si také, že 1 přímka dělí rovinu na dvě části, jen pro lepší pochopení důkazu.)
Mějme nyní rovinu rozdělenou n přímkami na nejvýše |n(n+l) + l částí. Další, (n+1)-ní přímka je rozdělena průsečíky s předchozími přímkami na nejvýše n + 1 úseků a každý z nich oddělí novou část roviny. Celkem tedy bude rovina rozdělena našimi přímkami na nejvýše tento počet oblastí:
1 111
-n(n + l) + l + (n + 1) = -n(n + 1) + - • 2(n + 1) + 1 = -(n + l)(n + 2) + 1
□
Příklad 2.8. Další indukční důkaz rozepsaný v podrobných krocích.
■vn • _ n(n+
Věta. Pro každé n > 0 platí ^™=0 j — n(n+1)
Důkaz indukcí vzhledem k n.
i í M 1 r*r\r7 i o "\ t f nmfn nřmono y/~v\ rvi r\c\- \
0:
Jestliže platí ^™=0 j = n(n+1), pak platí Yľj=o j = q^q^, kde q = n + 1.
m • _ n(n+
Předpokládejme tedy, že Y^j=oJ = n(n2+1') a pokusme se dokázat, že pak také
y- . _ g(g+ 1) _ (w + l)(w + 2) 2-^J ~ 2 ~ 2
j=0
To už plyne úpravou:
A. A. , 1N n(n + l) . 1N n(n + l)+2(n + l) (n + l)(n + 2) j=0 j=0
Podle principu matematické indukce je celý důkaz hotov. □
Poznámka: Výsledek Příkladu 2.8 je ukázkou tzv. sumačního vzorce pro posloupnost přirozených čísel. Jinou ukázkou je třeba vztah
1 + 3 H-----h (2n - 3) + (2n - 1) = 1 + (2n - 1) + 3 + (2n - 3) H----= 2n • ^ = n2,
nebo 12+22H-----hra2 = \n{n + l){2n + l) a 13+23H-----hra3 = (1 + 2 H-----h n)2 = \n2{n + l)2.
Odvozování a práce s jednoduchými sumačními vzorci by také měla náležet do výbavy schopného informatika, princip matematické indukce je zde klíčový.
16
2.4 Komentáře k matematické indukci
Pro správné a úspěšné použití indukce v dokazování je vhodné si zapamatovat několik cenných rad:
* Základní trik všech důkazů matematickou indukcí je vhodná reformulace tvrzení T(n + 1) tak, aby se „odvolávalo" na tvrzení T(n).
- Dobře se vždy podívejte, v čem se liší tvrzení T(n + 1) od tvrzení T(n). Tento „rozdíl" budete muset v důkaze zdůvodnit.
* Pozor, občas je potřeba „zesílit" tvrzení T(n), aby indukční krok správně „fungoval".
- Velkým problémem bohužel je, že není možno podat návod, jak vhodné „zesílení" nalézt (ani kdy jej vůbec hledat). Jedná se vlastně o pokusy a „hádání z křišťálové koule".
* Často se chybuje v důkazu indukčního kroku, neboť ten bývá většinou výrazně obtížnější než báze, ale o to zrádnější jsou chyby v samotné zdánlivě snadné bázi!
- Dejte si dobrý pozor, od které hodnoty n > k0 je indukční krok univerzálně platný a jestli případně báze nezahrnuje více než jednu hodnotu...
Zesílení indukčního kroku
Příklad 2.9. Když je nutno indukční krok zesílit... Věta. Pro každé n > 1 platí
,,111 1
s(n) =--1---1---1-----h —-r < 1.
y J 1-2 2-3 3-4 n(n + l)
Důkaz: Báze indukce je zřejmá, neboť ^ < 1.
Co však indukční krok"? Předpoklad s(n) < 1 je sám o sobě „příliš slabý" na to, aby bylo možno tvrdit s(n + 1) = s(n) + , , A , < 1.
\ 1 / v / (n+l)(n+2)
Neznamená to ještě, že by tvrzení nebylo platné, jen je potřeba náš indukční předpoklad zesílit. Budeme dokazovat
Tvrzení. Pro každé přirozené n > 1 platí s(n) < 1 — ^j-j- < 1.
To platí pro n = 1 (nezapomeňte ověřit!) a dále už úpravou jen dokončíme zesílený indukční krok:
l i i
s(n + l) = s(ri) + ----r < 1
(n + l)(n + 2) ~ n + 1 (n + l)(n + 2)
-(n + 2) + l _ x J_ (n + l)(n + 2) ' n+ 2
□
Rozšíření báze a předpokladu
Mimo zesilování tvrzení indukčního kroku jsme někdy okolnostmi nuceni i k rozšiřování samotné báze indukce a s ní indukčního předpokladu na více než jednu hodnotu parametru n.
17
- Můžeme například předpokládat platnost (parametrizovaných) tvrzení T(n) iT(n + l) zároveň, a pak odvozovat platnost T(n+2). Toto lze samozřejmě zobecnit na jakýkoliv počet předpokládaných parametrů.
- Můžeme dokonce předpokládat platnost tvrzení T(j) pro všechna j = k0, k0 + 1,..., n najednou a dokazovat T(n + 1). Toto typicky využijeme v případech, kdy indukční krok „rozdělí" problém T(n + 1) na dvě menší části a z nich pak odvodí platnost T(n + 1).
Fakt: Obě prezentovaná „rozšíření" jsou v konečném důsledku jen speciálními instancemi základní matematické indukce; použité rozšířené možnosti pouze zjednodušují formální zápis důkazu.
Příklad 2.10. Když je nutno rozšířit bázi a indukční předpoklad... Věta. Nechť funkce f pro každé n > 0 splňuje vztah
/(n + 2)=2/(n + l)-/(n).
Pokud platí /(O) = 1 a zároveň /(l) = 2, tak platí f(n) = n + 1 pro všechna přirozená n > 0.
Důkaz: Už samotný pohled na daný vztah f(n + 2) = 2f(n + 1) — f(n) naznačuje, že bychom měli rozšířit indukční předpoklad (a krok) zhruba takto:
Pro každé n > 0; jestliže platí T (n); neboli f(n) = n + 1, a zároveň platí T (n + 1); f(n + 1) = n + 2, pak platí také T(n + 2); f(n + 2) = n + 3.
Báze indukce - pozor, zde už musíme ověřit dvě hodnoty
/(O) = 0 + 1 = 1, /(l) = 1 + 1 = 2.
Náš indukční krok tak nyní může využít celého rozšířeného předpokladu, znalosti hodnot f(n) i f{n + 1), pro ověření
f(n + 2) = 2f(n + 1) - f{n) = 2-(n + l + l)-(n + l)=n + 3 = n + 2 + l.
□
Komentář: Jak by tento důkaz měl být formulován v „tradiční" indukci? („Substitucí" nového tvrzení.)
Závěrem malý „problém"
Příklad 2.11. Aneb jak snadno lze v matematické indukci udělat chybu. Věta. („nevěta")
V každém stádu o n > 1 koních mají všichni koně stejnou barvu.
Důkaz indukcí vzhledem k n. Báze: Ve stádu o jednom koni mají všichni koně stejnou barvu.
Indukční krok: Nechť S = \K\,..., Kn+i} je stádo o n + 1 koních. Dokážeme, že všichni koně mají stejnou barvu. Uvažme dvě
- S' = {K1,K1,...,Kn}
- S" = {K2,...,Kn,Kn+1)
18
Podle indukčního předpokladu mají všichni koně ve stádu S' stejnou barvu B'. Podobně všichni koně ve stádu S" mají podle indukčního předpokladu stejnou barvu B". Dokážeme, že B' = B", tedy že všichni koně ve stádu S mají stejnou barvu. To ale plyne z toho, že koně K2,..., Kn patří jak do stáda S', tak i do stáda S". □
Komentář: Ale to už je podvod! Vidíte, kde?
Navazující studium
Jak jsme již řekli, matematické důkazy a jejich chápání jsou nezbytné ke studiu vysokoškolských matematických předmětů. Bez schopnosti přesného vyjadřování a chápání deňnic a vět se informatik neobejde, ani pokud se zaměřuje čistě aplikovaným směrem; viz třeba správné pochopení různých norem a speciňkací.
Na druhou stranu umění "tvořit" nové matematické důkazy je dosti obtížné a nedá se jemu jen tak snadno naučit - vyžaduje to mnoho pokročilé praxe. Jelikož je schopnost formálního matematického dokazování nezbytná (převážně jen) v teoretických informatických disciplínách, není tato část kritická v celém předmětu (a u zkoušek se objevíš menším důrazem), ale to neznamená, že byste se jí mohli zcela vyhýbat. Obzvláště techniku matematické indukce by měl každý informatik aspoň trochu ovládat, neboť s jejím použitím se zajisté ještě mnohokráte setkáte v budoucím studiu.
19
3 Množiny, množinové operace
Úvod
V přehledu matematických formalismů informatiky se v této a příští lekci zaměříme na základní datové typy matematiky, tj. na množiny, relace a funkce. Netradiční sousloví „datové typy" matematiky zde volíme záměrně, abychom zdůraznili jejich fundamentálnost pro výstavbu navazující teorie v analogii k programování.
O množinách jste sice zajisté slyšeli už na základní škole, ale podstatou našeho předmětu je uvést povětšinou neformálně známé pojmy na patřičnou formální úroveň nutnou pro teoretické základy informatiky V případě konečné teorie množin si zde vystačíme s tzv. „naivním" pohledem, který dostatečně matematicky přesně vystihuje všechny jejich konečné aspekty (o komplikacích nekonečných množin se krátce zmíníme až v Lekci 12).
Cíle
V této lekci si ukážeme první krok k seriózně vybudované matematické teorii množin -tzv. naivní teorii množin, která nám velmi dobře poslouží ve všech konečných případech. Na to navážeme zavedením základního množinového kalkulu a shrnutím běžných vlastností množin. Závěrem si uvedeme příklady rekurzivně definovaných posloupností.
3.1 Pojem množiny
Položme si hned na úvod tu nej důležitější otázku: Co je vlastně množina?
Na tuto otázku bohužel není zcela jednoduchá odpověď... Abychom se vůbec někam
v našem úvodu dostali, spokojíme se zatím jen s přirozeným „naivním pohledem".
Definice naivní teorie množin: „Množina je soubor prvků a je svými prvky plně určena. "
Komentář: Příklady zápisu množin výčtem prvků
0, {a,b}, {b, a}, {a,b,a}, {{a, b}}, {0, {0}, {{0}}}, {x \ x je liché přirozené číslo}.
Co je ale pak prvek? Tady pozor, pojem prvku sám o sobě nemá matematický význam, svého významu totiž nabývá pouze ve spojení „být prvkem množiny". Prvky množiny tak může být cokoliv, mimo jiné i dalším množiny.
Komentář: Relativitu významu vztahu „prvek-množina" si můžeme přiblížit třeba na vztahu „podřízený-nadřízený" z běžného pracovního života. Tam také nemá smysl jen říkat, že je někdo podřízeným, aniž řekneme také jeho nadřízeného. Přitom i vedoucí je někomu ještě podřízený a naopak i ten poslední podřízený pracovník může být pánem třeba svého psa. Podobně je tomu s množinou jako „nadřízenou" svých prvků.
Ale přece jenom... v dobře definovaném kontextu lze (omezeně) mluvit o prvcích jako samostatných entitách. Formálně se například jedná o prvky pevně dané nosné množiny.
Značení množin a jejich prvků:
• x G M „x je prvkem množiny M",
• 0 je prázdná množina {}.
20
Komentář: Některé vlastnosti vztahu „být prvkem" jsou
* at{a,b}, a^{{a,b}}, {a, b} £ {{a, &}}, a 0 0, 0 £ {0}, 0 0 0,
* rovnost množin dle svých prvků {a,b} = {b, a} = {a,b,a}, {a, b} ^ {{a, b}}. Značení: Počet prvků (mohutnost) množiny A zapisujeme \A\.
Komentář: |0| = 0, |{0}| = 1, \{a,b,c}\=3, \{{a, b}, c}\ = 2.
Jednoduché srovnání množin
Vztah „být prvkem množiny" přirozeně nám podává i způsob porovnávání množin mezi sebou. Jedná se o klíčovou část teorie množin.
Definice: Množina A je podmnožinou množiny B, právě když každý prvek A je prvkem B. Píšeme A C B nebo obráceně B D A. Říkáme také, že se jedná o inkluzi.
* Platí {a} C {a} C {a, b} £ {{a, b}}, 0 C {0},
* A C B právě když A C B &, A ^ B (A je vlastni podmnožinou B). Z naivní definice množiny pak přímo vyplývá následující:
Definice: Dvě množiny jsou si rovny A = B právě když A C B & B C A.
* Podle naivní definice jsou totiž množiny A a, B stejné, mají-li stejné prvky.
* Důkaz rovnosti množin A = B má obvykle dvě části: Odděleně se dokáží inkluze A C B a B C A.
Ukázky nekonečných množin
Značení: Běžné číselné množiny v matematice jsou následující
* N = {0,1, 2, 3,... } je množina přirozených čísel,
* Z = {..., —2, — 1, 0,1, 2, 3,... } je množina celých čísel,
* Z+ = {1, 2, 3,... } je množina celých kladných čísel,
* Q je množina racionálních čísel (zlomků).
* R je množina reálných čísel.
Komentář: Tyto uvedené číselné množiny jsou vesměs nekonečné, na rozdíl od konečných množin uvažovaných v předchozím „naivním" pohledu. Pojem nekonečné množiny se přímo v matematice objevil až teprve v 19. století a bylo s ním spojeno několik paradoxů ukazujících, že naivní pohled na teorii množin pro nekonečné množiny nedostačuje. My se k problematice nekonečných množin, Kantorově větě a Russelově paradoxu vrátíme v závěru našeho předmětu v Lekci 12.
3.2 Množinové operace
Začněme se základními operacemi množinového kalkulu, které zajisté na intuitivní úrovni již ovládáte ze školy. Pro formální úplnost podáme jejich přesné definice, na které se můžete odvolávat v důkazech.
21
Sjednocení a průnik
Definice 3.1. Sjednocení U a průnik H dvou množin A, B definujeme
AU B = {x \ x e A nebo x G B} ,
A H B = {x \ x £ A & současně x G B} .
AU B
AnB
* Příklady {a, b, c} U {a, d} = {a, b, c, d}, {a, b, c} H {a, d} = {a}.
* Vždy platí „distributivita" A f] (B U C) = (A f] B) U (A f] C) a A U (B D C) = (AU B) (1 (AU C)
* a také „asociativita" Ar\(BC\C) = (Ar\B)C\C (stejně pro U) a „komutativita" AC\B = B H A (stejně pro U).
Komentář: Asociativita a komutativita operací sjednocení a průniku je na jednu stranu zcela přirozená, na druhou stranu však velmi důležitá například pro platnost následující definice.
Definice: Pro libovolný počet množin indexovaných pomocí I rozšířeně definujeme
^ Ai = {x | x G A-i pro nějaké i E 1} , ^ Ai = {x | x G Ai pro každé i G /} .
Komentář: Nechť Ai = {2 • i} pro každé i G N. Pak U«eN ^* Je množina všech sudých přirozených čísel. Nechť Bi = {x \ x G N, x > i} pro každé i G N. Pak HíeN Bi = 0-
Množinový rozdíl
Definice 3.2. Rozdíl \ a symetrický rozdíl A dvou množin A, B definujeme
A\B = {x \ x £ A &, současně x ^ B} , AAB = (A\B) U (B\ A) .
A\B ^^-JxC^ AAB
* Příklady {a, b, c} \ {a, b, d} = {c}, {a, b, c}A{a, b, d} = {c, d}.
* Vždy platí například A \ (B n C) = (A \ B) U (A \ C) apod.
Definice: Pro libovolný počet množin indexovaných pomocí konečné I rozšířeně defin-
/V^j Ai = {x | x G Ai pro lichý počet i G /} .
ujeme
22
Komentář: Povšimněte si, že operace rozdílu není asociativní ani komutativní (ostatně stejně je tomu u aritmetického rozdílu). Symetrický rozdíl už asociativní i komutativní je, není to však na první pohled vidět. Uměli byste toto dokázat?
Definice: Nechť A C M. Doplňkem A vzhledem k M je množina A = M \ A.
Komentář: Jedná se o poněkud specifickou operaci, která musí být vztažena vzhledem k nosné množině M ! Je-li M = {a, b, c}, pak {a, b} = {c}. Je-li M = {a, b}, pak {a, b} = 0.
* Vždy pro ACM platí A = A („dvojí" doplněk).
* Vždy pro A, B C M platí A U B = Iľl5a A H B = ÄUB. (Viz Vennovy diagramy.) Uspořádané dvojice a kartézský součin
Zatímco prvky v množinách jsou zcela neuspořádané, jsou mnohé situace, kdy musíme pracovat se „seřazenými" výčty prvků. V teorii množin lze takovéto seřazení definovat oklikou následovně:
Definice: Uspořádaná dvojíce (a,b) je zadána množinou {{a}, {a, b}}.
Fakt: Platí (a, b) = (c, d) právě když a = c a současně b = d. Uměli byste toto sami dokázat přímo z podané definice?
* Co je podle definice (a, a)? Je to (a, a) = {{a}, {a, a}} = {{a}, {o}} = {{a}}-
Definice 3.3. Kartézský součin dvou množin A, B definujeme jako množinu všech uspořádaných dvojic ze složek z A a B
A x B = {(a, b) | a G A, b G B} .
* Příklady {a, b} x {a} = {(a, a), (6, a)}, {c, d} x {a, 6} = {(c, a), (c, b), {d, a), {d, b)}.
* Platí ř)xX = 0 = lxf) pro každou množinu X.
* Jednoduchá mnemotechnická pomůcka říká |Ax5| = |A|-|5|.
Definice: Pro každé k G N, k > 0 definujeme uspořádanou k-tící {a\, ■ ■ ■ , ak) induktivně
- (ai) = ai,
- (<2i, • • • ,di, <2i+l) = ((«1, • • • ,dí), <2i+l).
Všimněte si, že definice používá tzv. rekurentní vztah, blíže viz Oddíl 3.4.
Fakt: Platí (ai, • • • , a^) = (&i, • • • , bk) právě když a« = 6« pro každé i G N kde 1 < i < k.
Definice kartézského součinu více množin: Pro každé A; G N definujeme
A\ x A2 x • • • x Ak = {{dl-, a.2, ■ ■ ■ , Ok) I Oi G Ai pro každé 1 < i < k} .
* Například Z3 = ZxZxZ = k) \ i,j, k G Z}.
* Co je A°7 {0}, neboť jediná uspořádaná 0-tice je právě prázdná 0.
Poznámka: Podle uvedené definice není součin asociativní, tj. obecně nemusí platit, že A x {B x C) = {A x B) x C. V matematické praxi je někdy výhodnější uvažovat upravenou definici, podle níž součin asociativní je. Pro účely této přednášky není podstatné, k jaké definici se přikloníme. Prezentované definice a věty „fungují" pro obě varianty.
23
Potenční množina
Definice 3.4. Potenční množina množiny A, neboli množina všech podmnožin, je definovaná vztahem
2A = {B | B C A} .
Důkaz: Stručně indukcí podle \A\: Pro A = 0 platí \2A\ = |{0}| = 1. Pro každý další prvek b ^ A rozdělíme všechny podmnožiny A U {b} „napolovic" na ty neobsahující b a na ty obsahující b, tudíž
3.3 Porovnávání a určení množin
Pro obecnou ilustraci formálního množinového kalkulu si ukažme dva důkazy rovností mezi množinovými výrazy. Podobně lze (rozepsáním příslušných definic) rutinně dokazovat další množinové vztahy.
Věta 3.6. Pro každé dvě množiny A, B C M platí AU B = A C\ B.
Důkaz v obou směrech rovnosti.
. A U B C A n B: Pro x E M platí x E A U B, právě když x g AU B, neboli když zároveň x ^ A a x ^ B. To znamená x E A a, zároveň x E B, z čehož vyplývá požadované x G A H B.
• AU B D A C\ B: Pro x E M platí x G A H B, právě když x E A a, zároveň x E B, neboli když zároveň x £ A a x £ B. To znamená x AU B, z čehož vyplývá požadované x E A U B. g
Věta 3.7. Pro každé tři množiny A, B, C platí
Důkaz (viz ilustrační obrázek). —
. A\(BílC) C (A \ B) \J(A\C): Je-li x E A \ (B n C), pak x E A a zároveň x (jL (B C\ C), neboli x £ B nebo x £ C. Pro první možnost máme x E (A\ B), pro druhou x E (A\C).
. Naopak A \ (B n C) D (A \ B) U (A \ C): Je-li x E (A\ B) U (A \ C), pak x E (A\ B) nebo x E (A\C). Pro první možnost máme x E A a zároveň x £ B, z čehož plyne x E A a zároveň x £ (B H C), a tudíž x E A \ (B H C). Druhá možnost je analogická. n
□
A\(BnC) = (A \ B) \J(A\C).
24
Charakteristický vektor (pod)množiny
V případech, kdy všechny uvažované množiny jsou podmnožinami nějaké konečné nosné množiny X, což není neobvyklé v programátorských aplikacích, s výhodou využijeme následující reprezentaci množin.
Definice: Mějme nosnou množinu X = {xi,x2,... ,xn}. Pro A c X definujeme charakteristický vektor xa jako
Xa = (ci, C2,..., cn), kde Q = 1 pro Xi G A a q = 0 jinak.
Užitečnost této reprezentace je ilustrována také následnými fakty.
• Platí A = B právě když Xa = Xb-
• Množinové operace jsou realizovány „bitovými funkcemi"
sjednocení ~ OR, průnik ~ AND, symetrický rozdíl ~ XOR.
Princip inkluze a exkluze
Tento důležitý a zajímavý kombinatorický princip je někdy také nazýván „princip zapojeni a vypojenŕ. Používá se ke zjišťování počtů prvků množin s neprázdnými průniky.
Věta 3.8. Počet prvků ve sjednocení dvou či tří množin spočítáme:
\AUB\ = \A\ + \B\ - \AC\B\ \AUBUC\ = \A\ + \B\ + \C\ -\Ar\B\ - \AnC\ - \BnC\ + \AnBnC\
Důkaz: Uvedeme si podrobný důkaz prvního vztahu |A U 5| = \A\ + \B\ — \AC\ B\, přičemž druhá část je analogická (viz obrázková ilustrace). Nechť x G A U B. Pokud x B, tak je x G A a prvek x je započítán na pravé straně \A\ + \B\ — \A fl B\ právě jednou v \A\. Obdobně je to v případě x £ A. Nakonec pro x G A H B je ve vztahu \A\ + \B\ — \AC\B\ tento prvek x započítán také 1 + 1 — 1 = 1 krát. □
Komentář: Všimněte si, že Větu 3.8 lze stejně tak využít k výpočtu počtu prvků v průniku množin...
Příklad 3.9. Z 1000 televizí jich při první kontrole na výrobní lince má 5 vadnou obrazovku, 10 je poškrábaných a 12 má jinou vadu. Přitom 3 televize mají současně všechny tři vady a 4 jiné jsou poškrábané a mají jinou vadu. Kolik televizí je celkem vadných ?
Řešení: Dosazením \A\ = 5, \B\ = 10, \C\ = 12, \A H B n C\ = 3, (zde pozor) \A n B\ = 3 + 0, \A n C\ = 3 + 0, \B n C\ = 3 + 4 do Věty 3.8 zjistíme výsledek 17. □
25
Poznámka. Jen stručně, bez důkazu a bližšího vysvětlení, si uvedeme obecnou formu principu inkluze a exkluze:
n
im= e (-i)|j|-x-
j=l 0^7C{l,...,n} iel
(Jeho znalost nebude v předmětu vyžadována.)
3.4 Posloupnosti a rekurentní vztahy
Uspořádané fc-tice (Oddíl 3.2) jsou také nazývány konečnými posloupnostmi délky k, neboli seřazeními prvků z dané neprázdné množiny hodnot (opakování prvků je povoleno). Tento pohled lze přirozeně zobecnit na nekonečné posloupnosti, avšak musíme sáhnout k trochu složitějším pojmům:
Definice: Nekonečná posloupnost p je zobrazením z N do svého oboru hodnot H. neboli p : N —y H (viz také Oddíl 4.1 o funkcích). Mimo „funkčního" zápisu p (n) často používáme „indexovou" formu zápisu funkční hodnoty jako pn.
Poznámka: Oborem hodnot posloupnosti obvykle bývá nějaká číselná množina, ale může to být i jakákoliv jiná množina. Také definiční obor posloupnosti (tj. indexy) může začínat od nuly nebo i od jedničky, jak je v aplikacích potřeba.
• Příklady posloupností:
* Po = 0, pi = 2,... ,pi = 2i,... je posloupnost sudých nezáporných čísel.
* 3, 3.1, 3.14, 3.141,... je posloupnost postupných dekadických rozvojů tt.
* 1, —1, 1, —1,... je posloupnost určená vztahem Pí = (—1)*, i > 0.
* Pokud chceme stejnou posloupnost 1, —1, 1, —1,... zadat jako qi, i > 1, tak ji určíme vzorcem g« = (—
• Posloupnost je rostoucí (či klesající), pokud pn+± > pn (pn+i < Pn) Pro všechna n. Rekurentní definice posloupnosti
Slovem rekurentní označujeme takové definice (či popisy), které se v jistých bodech odvolávají samy na sebe. (Už jste se setkali s „rekurzí" při programování? A víte, co znamená?) Místo nepřehledných formálních definic si rekurentní vztahy uvedeme několika názornými ukázkami.
• Zadáme-li posloupnost pn vztahy p0 = 1 a pn = 2pn_1 pro n > 0, pak platí pn = 2n pro všechna n.
• Obdobně můžeme zadat posloupnost qn vztahy qľ = 1 a qn = qn-\ + n pro n > 1. Potom platí qn = ^n(n + 1) pro všechna n. Uměli byste toto dokázat indukcí? Viz Příklad 2.8.
• Známá Fibonacciho posloupnost je zadaná vztahy f\ = f'2 = 1 a fn = fn-\ + fn-2 Pro n > 2.
Příklad 3.10. Posloupnost f je zadaná rekurentní defínicí
/(O) = 3 a /(n + l) = 2-/(n) + l
26
pro všechna přirozená n. Určete hodnotu f(n) explicitním vzorcem v závislosti na n.
Řešení: V první fázi řešení takového příkladu musíme nějak „uhodnout" hledaný vzorec pro f(n). Jak? Zkusíme vypočítat několik prvních hodnot a uvidíme...
/(I) = 2-/(0) + l=2-3 + l = 7
f (2) = 2-/(l) + l =2-7+1 = 15
/(3) = 2 • f (2) + 1 = 2 • 15 + 1 = 31
/(4) = 2-/(3) + l =2-31 + 1 =63
Nepřipomínají nám tato čísla něco? Co třeba posloupnost 8 — 1, 16 — 1, 32 — 1, 64 — 1... ? Bystrému čtenáři se již asi podařilo uhodnout, že půjde o mocniny dvou snížené o 1. Přesněji, f(n) = 2n+2 — 1 (proč je exponent n + 2? inu proto, aby správně vyšlo /(O)).
Ve druhé nesmíme ale zapomenout správnost našeho „věštění" dokázat, nejlépe matematickou indukcí podle n. . Báze: /(O) = 20+2 -1 = 4-1 = 3 platí.
• Indukční krok: za využití indukčního předpokladu
f(n + 1) = 2 • f(n) + 1 = 2- (2n+2 - 1) + 1 = 2 • 2n+2 - 2 + 1 = 2(n+1)+2 - 1. což také platí.
Podle principu matematické indukce je nyní dokázáno, že pro zadanou rekurentní posloupnost / platí f(n) = 2n+2 — 1 pro všechna přirozená n. □
Navazující studium
I když jste se s "množinami" setkávali už od základní školy, do matematické teorie množin asi nahlédnete na VS poprvé. Nezalekněte se na úvod formality vyjadřování, která je bohužel nezbytná, a naučte se s množinami a relacemi dobře pracovat aspoň na zde ukázané naivní úrovni konečné teorie množin. (Lehký náhled na obecně nekonečné množiny a jejich zdánlivé paradoxy i informatické aplikace si ukážeme později v Lekci 12...)
Dále si srovnejte pojem posloupnosti s pojmem funkce v Oddílu 4.1 a také si později povšimněte blízké koncepční podobnosti rekurentních deňnic s induktivními deňnicemi množin a funkcí v Oddíle 6.3.
27
4 Relace a jejich použití
Úvod
V návaznosti na předchozí lekci si podrobně rozebereme matematické formalismy relací a funkcí coby jejich speciálního případu. Na rozdíl od množin, které se v jisté velmi naivní formě objevují už na základní škole, se relacím v jejich abstraktní podobě mnoho pozornosti ve výuce nevěnuje. Stejně tak s pojmem funkce jste se již setkali na nižších stupních škol, ale povětšinou jen ve spojení s aritmetickými a analytickými funkcemi tvaru x + 1, x2 — y, či sin x, 1 + cos x2, atd.
Jak uvidíte nyní, pojmy relace i funkce jsou zcela abstraktní a neváže se ně žádný analytický vzorec výpočtu či podobné. Přitom na pojem (zcela obecné) relace velmi brzo narazí každý informatik při studiu dat a databází, které nad těmito pojmy staví. Není to však jen oblast relačních databází, ale i jiná místa informatiky, kde se obecné funkce a relace skrývají či přímo explicitně objevují. Nejčastěji se tak setkáte s binárními relacemi nad množinami, na něž se v textu dále zaměříme.
Cíle
Úkolem této lekce je vybudovat matematický aparát (konečných) relací, s primárním zaměřením na funkce a binární relace typu ekvivalence a uspořádání nad množinou. Ve vztahu k binárním relacím je zavedeno množství pojmů, které jsou později užitečné v různých oblastech matematiky i informatiky. V obecnosti jsou také vysvětleny inverze relací a jejich skládání. Látka pak plynule pokračuje Lekcí 5.
4.1 Relace a funkce nad množinami
Vedle množin dalším důležitým základním „datovým typem" matematiky jsou relace, kterým vzhledem k jejich mnohotvárnému použití v informatice věnujeme významnou pozornost v této i dvou příštích lekcích.
Definice 4.1. Relace mezi množinami A±,A2, ■ ■ ■ ,Ak, pro k G N, je libovolná podmnožina kartézského součinu
R C A1 x A2 x • • • x Ak.
Pokud A\ = A2 = ■ ■ ■ = Ak = A, hovoříme o k-ární relaci R na A. Speciálně tak mluvíme třeba o binární (k = 2), ternární (k = 3) nebo unární (k = 1) relaci.
Komentář: Příklady relací.
* {(1, a), (2, a), (2, b)} je relace mezi {1, 2, 3} a {a, b}.
* {(i, 2 • i) j i G N} je binární relace na N.
* {(i,j,i + j) G N} je ternární relace na N.
* {3 • i j i G N} je unární relace na N.
* Jaký význam vlastně mají unární a nulární relace na A?
Uvědomme si, jak obecně je relace definována - její definice umožňuje podchytit skutečně libovolné „vztahy" mezi prvky téže i různých množin. V praxi se relace velmi široce využívají třeba v relačních databázích...
28
Funkce mezi množinami
Za první setkání s instancemi relací se většinou dá považovat pojem funkce. Přitom tradiční „školní" pojetí funkce ji obvykle identifikuje s nějakým výpočetním (analytickým) předpisem či vzorcem. Pojem funkce je však daleko obecnější a zcela abstraktní, což si v této části textu bohatě ilustrujeme i pro lepší pochopení obecnějšího pojmu relace.
Definice 4.2. (Totální) funkce z množiny A do množiny B
je relace / mezi A a, B taková, že pro každé x E A existuje právě jedno y E B takové, že {x, y) E /. Množina A se nazývá definiční obor a množina B obor hodnot funkce /.
Komentář: Neformálně řečeno, ve funkci / je každé „vstupní" hodnotě x přiřazena jednoznačně „výstupní" hodnota y. (V obecné relaci počty „přiřazených" dvojic neomezujeme. ..)
Na druhou stranu si všimněte, že definiční obor i obor hodnot jsou součástí definice konkrétní funkce, neboli například v ukázce je oborem hodnot B = {a, b, c, d}, přestože samotné c není hodnotou pro žádný vstup.
Značení: Místo (x,y) G / píšeme obvykle f(x) = y. Zápis / : A —>• B říká, že / je funkce s definičním oborem A a oborem hodnot B. Funkcím se také říká zobrazení
Komentář: Příklady funkcí jsou třeba následující.
* Definujeme funkci / : N —> N předpisem f (x) = x + 8. Pak / = {(x, x + 8) | x G N}.
* Definujeme funkci plus :NxN-íN předpisem plus (i, j) = i + j. Pak plus = {(i, j, i + j) \i,j G N}.
Definice: Pokud naši Definici 4.2 upravíme tak, že požadujeme pro každé x E A nejvýše jedno y E B takové, že (x, y) E f, obdržíme definici parciální funkce z A do B.
Komentář:
V parciální funkci / nemusí být pro některé „vstupní" hodnoty x funkční hodnota definována (viz například f (2) v uvedeném obrázku).
Pro nedefinovanou hodnotu používáme znak _L.
Komentář: Následuje několik příkladů parciálních funkcí.
29
* Definujeme parciální funkci / : TL —> N předpisem
, . í 3 + x jestliže x > 0. Hx>=\ j_ jinak.
Tj. / = {(x,3 + x) | x G N}.
* Také funkce / : R —> R daná běžným analytickým předpisem f(x) = log x je jen parciální - není definována pro x < 0.
* Co je relace, přiřazující lidem v CR jejich (česká) rodná čísla?
4.2 Reprezentace konečných relací
Oblastí, kde informatici nejčastěji potkají obecné relace, je bezesporu ukládání dat. To proto, že shromažďovaná data, stejně jako relace, především sledují vztahy mezi objekty. Na druhou stranu je relační databáze zcela obecnou ukázkou reprezentace jakékoliv relace, kterou si ilustrujeme příkladem.
Příklad 4.3. Tabulka relační databáze prezentuje obecnou relaci. Definujme následující množiny („elementární typy")
* ZNAK = {a, • • • ,z,A,--- , Z, mezera},
* ČÍSLICE = {0,1, 2, 3,4, 5, 6, 7, 8, 9}.
Dále definujeme tyto množiny („odvozené typy")
* JMÉNO = ZNAK15, PŘÍJMENÍ = ZNAK20, VEK = ČÍSLICE3,
* ZAMESTNANEC „G" JMÉNO x PŘÍJMENÍ x VEK. Relaci „typu" ZAMESTNANEC pak lze reprezentovat tabulkou:
jméno příjmení vek
Jan Novák 42
Petr Vichr 28
Pavel Zima 26
Stanislav Novotný 52
□
Reprezentace binárních relací na množině
Jistě čtenáři uznají, že zadání relace výčtem jejích složek není pro člověka (na rozdíl od počítače) tím nej příjemnějším způsobem. Je tedy přirozené se ptát, jak co nejnázorněji takovou relaci, alespoň v její nejčastější binární podobě, ukázat.
Značení: Binární relaci i? C M x M lze jednoznačně znázornit jejím grafem:
• Prvky M znázorníme jako body v rovině.
• Prvek (a, b) G R znázorníme jako orientovanou hranu („šipku") z a do b. Je-li a = b, pak je touto hranou „smyčka" na a.
30
Komentář: Například mějme M = {a,b,c,d,e, /} a R = {(a,a),(a,b),(b,c),(b,d). (b, e), (b, /), (d, c), (e, c), (/, c), (e, antísymetrícká, právě když pro každé a,b G M platí, že jestliže (a, b), (b, a) G i?, pak a = b:
> tranzitívni, právě když pro každé a,b,c G M platí, že jestliže (a,b), (b,c) G R, pak také (a, c) G i?.
Následují dva základní typy binárních relací; kde i? je
• relace ekvivalence, právě když je i? reflexivní, symetrická a tranzitivní:
• částečné uspořádání, právě když je R reflexivní, antisymetrická a tranzitivní (často říkáme jen uspořádání).
Komentář: Pozor, může být relace symetrická i antisymetrická zároveň? Ano!
Vezměte si relaci R = {(x, x) \ x G M}, která obě jmenované vlastnosti splňuje. Proto pokud jste třeba dotázáni, zda relace je symetrická, nestačí se v odpovědi odvolávat na fakt, že je antisymetrická(!), neboť tyto vlastnosti se nevylučují.
<í> <í> <í>
Příklad 4.5. Několik příkladů relací defínovaných v přirozeném jazyce.
Nechť M je množina všech studentů 1. ročníku FI. Uvažme postupně relace R C M x M definované takto
* (x, y) G R právě když x a y mají stejné rodné číslo:
* (x, y) G R právě když x má stejnou výšku jako y (dejme tomu na celé mm):
* (x, y) E R právě když výška x a y se neliší více jak o 2 mm:
* (x, y) E R právě když x má alespoň takovou výšku jako y:
* (x, y) E R právě když x má jinou výšku než y (dejme tomu na celé mm):
* (x, y) G R právě když x je zamilován(a) do y.
Zamyslete se podrobně, které z definovaných vlastností tyto jednotlivé relace mají. Které z nich tedy jsou ekvivalencí nebo uspořádáním? □
Příklad 4.6. Jaké vlastnosti mají následující relace?
* Buď f? C N x N definovaná takto (x, y) G R právě když x dělí y. (Částečné uspořádání. ale ne každá dvě čísla jsou porovnatelná.)
* Buď i?CNxN definovaná takto (x, y) G R právě když x a, y mají stejný zbytek po dělení číslem 5. (Ekvivalence.)
* Nechť F = {f \ f : ¥S —^N}je množina funkcí. Buď R C F x F definovaná takto (f, g) G R právě když f (x) < g (x) pro všechna x. (Ireňexivní, antisymetrická a tranzitivní, ale ne reflexivní - striktně řečeno není uspořádáním.) □
32
Komentář: Co v případě, že naše relace některou z poptávaných vlastností nemá, ale nám by se ta vlastnost hodila? To řeší tzv. uzávěry relací:
• Reflexivní uzávěr jednoduše přidá do relace všechny dvojice (x, x) nad nosnou množinou.
• Symetrický uzávěr zahrne do relace všechny obrácené dvojice k existujícím dvojicím, neboli všechna chybějící (x, y) pokud (y, x) £ R.
• Tranzitivní uzávěr nelze popsat až tak jednoduše, ale stručně řečeno přidává do relace všechny ty dvojice (x,y), pro které se lze (v grafu relace) dostat z x do y „po šipečkách".
Formálně se této problematice uzávěrů relací bude věnovat Oddíl 6.4.
4.4 Inverzní relace a skládání relací
Ve výkladu se nyní vrátíme k obecnému pojetí relací mezi (třeba různými) množinami. K použitelné práci s relacemi v aplikacích se dostaneme, pokud budeme umět relace správně „převracet" a „skládat". To nám umožní následující definice.
Definice: Nechť R C A x B je binární relace mezi A a B. Inverzní relace k relaci R se značí R~ľ a je definována takto:
R-1 = {(b,a) | (a, b) G R}
R 1 je tedy relace mezi B a A.
Následuje klíčová definice, pro jejíž bližší ilustraci odkazujeme také na Příklad 4.8.
Definice 4.7. Složení (kompozice) relací R a S.
Nechť RCAxB&SCBxC jsou binární relace. Složení relací R a S (v tomto pořadí!) je relace S o R G A x C definovaná takto:
S o R = {(a, c) I existuje b E B takové, že (a, b) G R, (b, c) G S}
Komentář: Několik matematických příkladů skládání relací následuje zde.
-A = {a,b}, 5 = {1,2}, C = {X,Y}.,
33
- R = {{a, 1), (6,1), (b, 2)}, S = {(1,X)}, pak složením vznikne relace
- S o R = {(a, X), (b, X)}.
* Složením funkcí h(x) = x2 a f (x) = x + 1 na R vznikne funkce
(foh)(x)=f(h(x)) = x2 + l.
* Složením těchže funkcí „naopak" ale vznikne funkce (h o /) (x) = h(f(x)) = (x + l)2-
Poznámka: Nepříjemné je, že v některých oblastech matematiky (například v algebře při skládání zobrazení) se setkáme s právě opačným zápisem skládání, kdy se místo S o R píše R ■ S nebo jen RS. Proto je si vždy dobré slovně ujasnit, které pořadí skládaných relací máme na mysli. My zde zásadně budeme používat pořadí S o R.
4.5 Skládání relací „v praxi"
Podívejme se nyní, jak se skládání relací přirozeně objevuje v práci s relačními databázemi. (Dá se zjednodušeně říci, že právě v operátoru skládání tabulkových relací tkví hlavní smysl relačních databází...)
Příklad 4.8. Skládání v relační databázi studentů, jejich předmětů a fakult.
Mějme dvě binární relace - jednu R přiřazující studentům MU kódy jejich zapsaných předmětů, druhou S přiřazující kódy předmětů jejich mateřským fakultám. Malý výsek z těchto relací může v tabulkové reprezentaci vypadat třeba následovně.
R :
student (učo) předmět (kód)
121334 MA010
133935 M4135
133935 IA102
155878 M1050
155878 IB000
S :
předmět (kód) fakulta MU
MA010 FI
IB000 FI
IA102 FI
M1050 PřF
M4135 PřF
Jak z těchto „tabulkových" relací zjistíme, kteří studenti mají zapsané předměty na kterých fakultách (třeba na FI)?
Jedná se jednoduše o složení relací S o R. V našem příkladě tabulkové reprezentace vyjde výsledek:
SoR:
student (učo) fakulta MU
121334 FI
133935 FI
133935 PřF
155878 FI
155878 PřF
□
34
Zobecněné skládání relací
V praktických použitích relačních tabulek povětšinou nevystačíme jen s binárními relacemi, takže je přirozené se ptát, jestli lze podobně skládat i více-ární relace. Odpověď je snadná - lze to a ani nepotřebujeme novou definici, vystačíme s tou, kterou už máme výše uvedenou.
Definice: (skládání relací vyšší arity):
Mějme relace T C K\ x _řř2 x • • • x Kk a U C L\ x L2 x • • • x Lp, přičemž pro nějaké m < min(k,£) platí L\ = Kk-m+i, L2 = Kk-m+2, ■ ■ ■ ,Lm = Kk- Pak relaci T lze složit s relací U na zvolených m složkách L1;..., Lm („překrytí") s použitím Defínice 4.7takto:
x L ry) £1 C — Lf
x Lp.
* Položme A = Ki x ■ ■ ■ x Kk-m, B = L\X
* Příslušné relace pak jsou R = {(a, b) G A x B | (ai,... a^-m, b±,... bm) G T} a S = {(b,č) G B x C I (b1,...bm,cm+1,...ce) G U}.
* Nakonec přirozeně položme U om T ~ S o R, takže vyjde
UomT = {(a, č) j ex. 6 G -B, že (ai,... afc_m, 61,... bm) G T a (61,... bm, cm+1,... cp) G U) . Schematicky pro snadnější orientaci ve složkách našich relací:
T C Kxx U C
U om T C iři x
x Kk-m x Kk-m+1 X ■ ■ ■ X Kk
L\ X • • • X Lrp-y x L
m+1
x Lm+i x
x
x L/
c
Opět je nejjednodušší si koncept skládání vícečetných relací ilustrovat příkladem.
Příklad 4.9. Skládání v relační databázi pasažérů a letů u leteckých společností.
Podívejme se na příklad hypotetické rezervace letů pro cestující, relace T. Jak známo (tzv. codeshare), letecké společnosti si mezi sebou „dělí" místa v letadlech, takže různé lety (podle kódů) jsou ve skutečnosti realizovány stejným letadlem jedné ze společností. To zase ukazuje relace U.
T :
pasažér datum let datum let letadlo
Petr 5.11. OK535 5.11. OK535 CSA
Pavel 6.11. OK535 U : 5.11. AF2378 ČSA
Jan 5.11. AF2378 5.11. DL5457 ČSA
Josef 5.11. DL5457 6.11. OK535 AirFrance
Alena 6.11. AF2378 6.11. AF2378 AirFrance
Ptáme-li se nyní, setkají se Petr a Josef na palubě stejného letadla? Případně, čí letadlo to bude? Odpovědi nám dá složení relací U o2 T, jak je popsáno výše.
Uo2T:
pasažér letadlo
Petr Josef Pavel CSA ČSA AirFrance
35
Zkuste se zamyslet, lze tyto dvě relace skládat ještě jinak? Co by pak bylo významem?
□
Navazující studium
Mějte na paměti, že na pojmech množin, relací a funkcí jsou vystavěny prakticky všechny skutečné datové struktury používané v dnešní informatice. Explicitně toto můžete vidět na relačních databázích, ale i na mnoha jiných implicitních výskytech. Mnohem více si nejprve o relacích a poté speciálně o funkcích vysvětlíme v dalších dvou lekcích. Dalším důležitým matematickým datovým typem odvozeným z binárních relací jsou pak grafy probírané od Lekce 7.
36
5 Ekvivalence, Uspořádané množiny
Úvod
V této lekci pokračujeme rozebíráním relací na množinách jako nástrojů vyjadřujících vztahy mezi objekty. Zaměříme se přitom pouze na relace binární, které nějakým způsobem srovnávají objekty podle jejich vlastností (obvykle ve smyslu „ stejný jako" nebo „ lepší/větší než"). Takto vágně opsané binární relace mívají jasné společné znaky, které se pak objevují ve zde uvedených formálních dennících relace ekvivalence a uspořádání.
Co se týče ekvivalencí, lze šije neformálně představit jako rozdělení prvků nosné množiny na „hromádky", přičemž prvky každé jednotlivé hromádky jsou si navzájem v jistém smyslu stejné. Naopak uspořádání nám již podle svého názvu udává srovnání prvků nosné množiny, neboli které prvky si „stojí lépe" než jiné.
Cíle
Deňnujeme relace ekvivalence a uspořádání a mnohé další pojmy k nim se vztahující, například rozklady a Hasseovy diagramy. Studující by měli porozumět matematické problematice rozkladů množin a uspořádaných množin a naučit se je správně používat.
5.1 Relace ekvivalence
Nyní se hlouběji podívejme na první specifický typ binární relace zmíněný výše: Podle Definice 4.4 je relace R C M x M ekvivalence právě když R je reflexivní, symetrická a tranzitivní. Tyto tři vlastnosti tedy musí být splněny a ověřeny k důkazu toho, že daná relace i? je ekvivalence.
Komentář: Jak vypadá graf relace ekvivalence? Poměrně příznačně, jak nám ukazuje následující obrázek (všimněte si absence šipek, která je dána symetrií relace).
9
6
Neformálně řečeno; ekvivalence je relace i? C M x M, taková, že (x, y) G i? právě když x a y jsou v nějakém smyslu „stejné".
Značení. V případě relace ekvivalence se poměrně často lze setkat s označením jako ~ či místo R. Místo (x, y) G R se pak píše x »2 y.
Příklad 5.1. Necht! M je množina všech studentů 1. ročníku FI. Uvažme postupně relace R C M x M defínované následovně a zkoumejme, zda se jedná o ekvivalence:
* (x, y) E R právě když x má stejnou výšku jako y:
* (x, y) E R právě když x má stejnou barvu vlasů jako y:
* (x, y) G R právě když x, y mají stejnou výšku a stejnou barvu vlasů;
* (x, y) G R právě když x, y mají stejnou výšku nebo stejnou barvu vlasů.
37
U kterého body se nejedná o relaci ekvivalence a proč? Je to poslední případ, kdy není splněna tranzitivita. □
Uvedený příklad ukazuje na následující univerzální poznatek, který může platit (a taky platí) pouze pro průnik a nikoliv pro sjednocení.
Tvrzení 5.2. Nechi R, S jsou dvě relace ekvivalence na stejné množině M. Pak jejich průnik R C\ S je opět relací ekvivalence.
Důkaz (náznak): Jelikož reflexivita a symetrie je zřejmá, stačí snadno ověřit platnost tranzitivity na RílS. Nechť (a, b), (6, c) G RC\S, pak podle tranzitivity každé samostatné z R, S plyne (a, c) G R a zároveň (a, c) G S. □
Příklad 5.3. Nechť i? C N x N je binární relace defínovaná takto: (x,y) G R právě když \x — y\ je dělitelné třemi.
V jakém smyslu jsou zde x a, y „stejné"? Dávají stejný zbytek po dělení třemi. □
Příklad 5.4. Buď R binární relace mezi všemi studenty na přednášce FP.IB000 defínovaná takto: (x, y) G R právě když x i y sedí v první lavici.
Už na první pohled jde o relaci symetrickou a tranzitivní. Proč se v tomto případě nejedná o relaci ekvivalence? Protože není reflexivní pro studenty sedící v dalších lavicích. (Takže si dávejte dobrý pozor na správné pochopení definic.) □
5.2 Rozklady a jejich vztah k ekvivalencím
Náplní následující části výkladu je ukázat jiný přirozený pohled na ekvivalence. Tento nový pohled nám matematicky formalizuje představu ekvivalence jako rozdělení prvků nosné množiny M na „hromádky", přičemž prvky každé jednotlivé hromádky jsou si navzájem v jistém smyslu „stejné".
Definice 5.5. Rozklad množiny. Nechť M je množina.
Rozklad (na) M je množina podmnožin M C 2M splňující následující tři podmínky:
- 0 ^ M (tj. každý prvek M je neprázdná podmnožina M):
- pokud A,B eN, pak buď A = B nebo A H B = 0:
- UAeMA = M-
Prvkům M se také říká třídy rozkladu.
Komentář:
* Buď M = {a, b, c, d}. Pak M = {{a}, {b, c}, {d}} je rozklad na M.
* Nechť A0 = {k G N | k mod 3 = 0}, Ax = {k G N | k mod 3 = 1}, A2 = {k G N j k mod 3 = 2}. Pak J\í = {^0,^1,^2} je rozklad všech přirozených čísel N podle zbytkových tříd.
Každý rozklad M na M jednoznačně určuje jistou ekvivalenci R^f na M:
Věta 5.6. Nechi M je množina a M rozklad na M. Nechi R^f C M x M je relace na M definovaná takto
(x, y) G Rjy právě když existuje A E M taková, že x, y E A.
Pak Rjy je ekvivalence na M.
38
Důkaz: Dokážeme, že Rjy je reůexivní, symetrická a tranzitivní (Deňnice 4.4).
• Reflexivita: Buď x E M libovolné. Jelikož M je rozklad na M, musí existovat A E M takové, že x E A (jinak spor se třetí podmínkou z Defínice 5.5). Proto (x,x) E Rjy, tedy Rtf je reflexivní.
• Symetrie: Nechť (x,y) E Rjy. Podle definice Rjy pak existuje A E M taková, že x, y E A. To ale znamená, že také (y,x) E Rjy podle definice R^f, tedy Rjy je symetrická.
• Tranzitivita: Nechť (x,y), (y,z) E Rj^. Podle definice R^f existují A, B E M takové, že x,y E A a y, z E B. Jelikož A H B ^ 0, podle druhé podmínky z Defínice 5.5 platí A = B. Tedy x, z E A = B, proto (x, z) E Rjy podle definice Rj^. □
Každá ekvivalence R na, M naopak jednoznačně určuje jistý rozklad M/R na M:
Věta 5.7. Nechť M je množina a R ekvivalence na M. Pro každé x E M definujeme množinu
[x] = {yeM\ (x,y)ER}. Pak {[x] | x E M} je rozklad na M, který značíme M/R a čteme „rozklad M podle R".
Důkaz: Dokážeme, že M/r splňuje podmínky Defínice 5.5.
• Pro každé [x] E M/r platí [x] ^ 0, neboť x E [x].
• Nechť [x], [y] E M j r. Ukážeme, že pokud [x] H [y] ý Pak \x\ = \v\-
Jestliže [x] H [y] ý existuje z E M takové, že z E [x] a z E [y]. Podle definice [x] a [y] to znamená, že (x, z), (y, z) E r. Jelikož r je symetrická a (y, z) E r, platí (z, y) E r. Jelikož (x, z), (z, y) E r a r je tranzitivní, platí (x, y) E r. Proto také (y, x) E r (opět ze symetrie r). Nyní dokážeme, že [y] = [x]:
* v[x] = [y] ": Nechť v G [x]. Pak (x, v) G R podle definice [x]. Dále (y, x) G R (viz výše), tedy (y, v) G R neboť R je tranzitivní. To podle definice [y] znamená, že v G [y].
* „[y] - [x] ": Nechť v G [y]. Pak (y, v) G R podle definice [y]. Dále (x, y) G R (viz výše), tedy (x, v) G R neboť R je tranzitivní. To podle definice [x] znamená, že v G [x].
• Platí U [x] e m/í? W = M, neboť x E [x] pro každé x E M. 5.3 Uspořádání a uspořádané množiny
Přirozený vágní pojem porovnání/uspořádání objektů má také svou přesnou matematickou definici: Podle Definice 4.4 je relace r C M x M (částečné) uspořádání právě když i? je reflexivní, antisymetrická a tranzitivní. Tyto tři vlastnosti tedy musí být splněny a ověřeny k důkazu toho, že daná relace i? je uspořádáním.
39
Komentář: Neformálně řečeno: uspořádání je taková relace i? C M x M, kde (x,y) G R právě když x je v nějakém smyslu „menší nebo rovno" než y. Mohou ovšem existovat taková x, y G M, kde neplatí (x, y) G R ani (y, x) G R. (Pak říkáme, že x a y jsou nesrovnatelné.)
Jak názorně zobrazit (částečné) uspořádání? Příklad zjednodušeného zakreslení (jsou vynechány šipky vyplývající z reflexivity a tranzitivity, viz Oddíl 5.4) je zde:
8 12
dělitelnost:
Všimněte si, že je někdy zvykem „větší" prvky kreslit nad ty „menší".
Značení. Pro větší přehlednost se relace uspořádání často značí symboly jako C či ^ místo prostého R. I my tak často budeme psát třeba x ^ y místo (x, y) E R.
Poznámka: Zajisté jste se již neformálně setkali s „neostrým" uspořádáním čísel < a „ostrým" uspořádáním < . Všimněte si dobře, že námi definované uspořádání je vždy „neostré". Pokud byste naopak chtěli definovat „ostré" uspořádání, mělo by vlastnosti ireňexivní, antisymetrické a tranzitivní. (Příliš se však tato varianta nepoužívá.) Nadále budeme pracovat pouze s neostrým uspořádáním, ale smyčky vyplývající z reflexivity a případně i tranzitivity budeme pro větší přehlednost v obrázcích vynechávat.
Uspořádaná množina
Matematicky důležitějším pojmem než samotná relace uspořádání je uspořádaná množina, neboli soubor prvků s pevně zvoleným uspořádáním na nich.
Definice 5.8. Uspořádaná množina je dvojice (M, ^), kde M je množina a ^ je (částečné) uspořádání na M.
Definice: Uspořádání ^ na M je lineární (nebo také úplné), pokud každé dva prvky M jsou v -< srovnatelné.
Příklady uspořádaných množin
Příklad 5.9. Nechť M je množina všech studentů 1. ročníku FI. Uvažme postupně relace uspořádání R C M x M definované následovné (jedná se vždy o uspořádání?):
* (x, y) E R právě když x má alespoň takovou výšku jako y:
* (x, y) E R právě když y má alespoň takovou výšku jako x:
* (x, y) E R právě když x a y mají stejné rodné číslo.
Ano, i v posledním bodě se jedná o uspořádání. (Dobře si promyslete, proč. Které dvojice jsou vůbec porovnatelné?) □
Příklad 5.10. Další ukázky uspořádaných množin následují zde:
40
* (N, <) je lineárně uspořádaná množina, kde < má „obvyklý" význam.
* (N, | ), kde a\b je relace dělitelnosti „a dělí 6" na přirozených číslech, je uspořádaná množina. Toto uspořádání není lineární.
* Buď M množina. Pak (2M, C) je uspořádaná množina (říkáme inkluzi). Které dvojice jsou v uspořádání inkluzí nesrovnatelné!
Komentář: Zamyslete se také, jak vypadá relace dělitelnosti na celých (tj. i záporných) číslech. Proč se už nejedná o uspořádání? Blíže viz konec Oddílu 5.4.
Užitečnou dovedností je umět popsat uspořádání „větší množiny" pomocí „malých" složek. Neformálně lze toto uvést následujícími příklady:
Příklad 5.11. Uspořádání „po složkách".
Nechť (A, 2, pak množinu A\ x • • • x An lze uspořádat třeba po složkách nebo lexikografícky. Všimněte si, že lexikograficky se například řadí slova ve slovníku...
5.4 Další pojmy uspořádaných množin
K tématu uspořádaných množin se vztahuje množství drobných pojmů, které potkáte v různých oblastech matematiky i informatiky.
Definice 5.13. Nechť (M, ^) je uspořádaná množina. • x G M je minimální právě když pro každé y E M platí, že jestliže y ^ x, pak x ^ y. (Tj. x je minimální právě když neexistuje žádný prvek ostře menší než x.)
/
\
□
41
i G M je maximální právě když pro každé y E M platí, že jestliže x ^ y, pak y ^ x. (Tj. x je maximální právě když neexistuje žádný prvek ostře větší než x.)
x E M je nejmenší právě když pro každé y E M platí, že x b je
* ínjektívní (nebo také prostá) právě když pro každé x,y E a, x ^ y platí f(x) ý f{v)\
* surjektívní (nebo také „na") právě když pro každé y E b existuje x E a takové, že f (x) = y,
—í-2"-1
bíjektívní (vzáj. jednoznačná) právě když je injektivní a současně surjektivní.
"V—i
"V
x=--
Komentář: Následují jiné ukázky vlastností funkcí.
* Funkce plus : N x N —> N je surjektivní, ale není prostá.
* Funkce g : TL —> N daná předpisem
—2x — 1 jestliže x < 0,
2x
jinak
je bijektivní.
46
* Funkce 0 : 0 —> 0 je bijektivní.
* Funkce 0 : 0 —?► {a, b} je injektivní, ale není surjektivní.
* Dokázali byste nalézt bijektivní funkci NxN-> N?
Inverze funkce
Komentář: Příklady inverzí pro relace-funkce (viz Oddíl 4.4).
* Inverzí bijektivní funkce f(x) = x + 1 na Z je funkce f^1(x) = x — 1.
* Inverzí prosté funkce f(x) = ex na R je parciální funkce f^1(x) = lnx.
* Funkce g(x) = x mod 3 není prostá na N, a proto její inverzí je „jen" relace g^1 = {(a,b) a = b mod 3}. Konkr. g'1 = {(0, 0), (0, 3), (0, 6),... , (1,1), (1,4),... , (2, 2), (2, 5),... }.
Tvrzení 6.2. Mějme funkcí f : A —>• B. Pak její inverzní relace f~ľ je
a) parciální funkce právě když f je prostá,
b) funkce právě když f je bijektivní.
Důkaz vyplývá přímo z definic funkce a inverze relace. □ 6.2 Skládání funkcí, permutace
Soustřeďme se nyní na tuto další oblast, kde běžně a přirozeně používáme skládání relací, aniž si to uvědomujeme.
Fakt: Mějme zobrazení (funkce) f: A^tB&g: B^tC. Pak jejich složením coby relací v tomto pořadí vznikne zobrazení (g o /) : A —> C definované
Í9° f)(x) =g(f(x)).
Komentář:
* Jak například na běžné kalkulačce vypočteme hodnotu funkce sin2 x ? Složíme (v tomto pořadí) „elementární" funkce f(x) = sin x a g(x) = x2.
* Jak bychom na „elementární" funkce rozložili aritmetický výraz 21og(x2 + 1)? Ve správném pořadí složíme funkce fi(x) = x2, f2(2) = x + 1, fs(x) = log x a f±(x) = 2x.
* A jak bychom obdobně vyjádřili složením funkcí aritmetický výraz sin x + cos x? Opět je odpověď přímočará, vezmeme „elementární" funkce g\ (x) = sin x a g2Íx) = cosx, a pak je „složíme" další funkcí h(x, y) = x + y. Vidíme však, že takto pojaté „skládání" už nezapadá hladce do našeho zjednodušeného formalismu skládání relací.
Pro nedostatek prostoru si skládání funkcí s více parametry nedefinujeme, ale sami vidíte, že obdobné skládání se v programátorské praxi vyskytuje doslova „na každém rohu" a ani se nad tím nepozastavujeme.
Skládání permutací
Po zbytek tohoto oddílu se zaměříme na permutace coby speciální případ (bijektivních) zobrazení.
47
Definice: Nechť permutace 7r množiny {1,2,... ,n} je určena seřazením jejích prvků (pi,... ,pn)- Pak 7T je zároveň bijektivním zobrazením {1,... ,n} —> {1,... ,n} definovaným předpisem tt(í) = Pí. Tudíž lze permutace skládat jako relace podle Definice 4.7.
Poznámka: Všechny permutace množiny {1,2,... ,n} spolu s operací skládání tvoří grupu, zvanou symetrická grupa Sn. Permutační grupy (podgrupy symetrické grupy) jsou velice důležité v algebře, neboť každá grupa je vlastně isomorfní některé permutační grupě.
Komentář: Příkladem permutace vyskytujícím se v programátorské praxi je třeba zobrazení i i—> (i + 1) mod n ("inkrement"). Často se třeba lze setkat (aniž si to mnohdy uvědomujeme) s permutacemi při indexaci prvků polí.
V kontextu pohledu na funkce a jejich skládání coby relací si zavedeme jiný, názornější, způsob zápisu permutací - pomocí jejich cyklů.
Definice: Nechť 7r je permutace na množině A. Cyklem v 7r rozumíme posloupnost (ai, a2, ■ ■ ■, Ofc) různých prvků A takovou, že 7r(<2j) = ai+1 pro i = 1,2,..., k — 1 a 7r(afc) = d\.
Jak název napovídá, v zápise cyklu (ai, a2,..., ak) není důležité, kterým prvkem začneme, ale jen dodržení cyklického pořadí. Cyklus v permutaci může mít i jen jeden prvek (zobrazený na sebe).
Komentář: Nakreslete si (vámi zvolenou) permutaci tv obrázkem, ve kterém vedete šipku vždy od prvku i k prvku tt(í). Pak uvidíte, že cykly dle naší definice jsou právě cykly tvořené šipkami ve vašem obrázku. S tímto grafickým zobrazením pro vás nebude problém pochopit následující látku.
Například permutaci (5, 3,4, 8, 6,1, 7, 2) si lze obrázkem nakreslit takto:
Reprezentace permutací jejich cykly
Věta 6.3. Každou permutací tt na konečné množině A lze zapsat jako složení cyklů na disjunktních podmnožinách (rozkladu) A.
Důkaz: Vezmeme libovolný prvek a\ G A a iterujeme zobrazení a2 = 7r(ai), 03 = 7r(a2); atd., až se dostaneme „zpět" k a^+i = ^(a^) = d\- Proč tento proces skončí? Protože A je konečná a tudíž ke zopakování některého prvku a^+i musí dojít. Nadto je 7r prostá, a proto nemůže nastat 7r(afc) = a,j pro j > 1. Takto získáme první cyklus (a1;..., a^).
Induktivně pokračujeme s hledáním dalších cyklů ve zbylé množině A' = A \ {ai,..., aj-}, dokud nezůstane prázdná. V tomto indukčním kroku si musíme uvědomit, že 7T omezené na nosnou množinu A' je stále permutací podle definice (neboli žádná prvek z A' se nezobrazí do {a1;..., a^}). □
Značení permutace jejími cykly: Nechť se permutace 7r podle Věty 6.3 skládá z cyklů (ai,..., a*;), (61,... ,bi) až třeba (z1}..., zm). Pak zapíšeme
vr = ((ai,..., ak) (61,..., bi)... {zu ...,zm)).
48
Komentář: Primitivní pseudonáhodné generátory v počítačích iterují z náhodného počátku permutaci danou vztahem i i—> (i + p) mod q. Je pochopitelné, že tato permutace nesmí obsahovat krátké cykly, lépe řečeno, měla by se skládat z jediného (dlouhého) cyklu. (Pro úplnost, jedná se o permutaci množiny {0,1,... , q — 1}).
Příklad 6.4. Ukázka skládání permutací daných svými cykly.
Vezměme 7-prvkovou permutaci 7r = (3,4, 5, 6, 7,1, 2). Ta se skládá z jediného cyklu (1, 3, 5, 7, 2,4, 6). Jiná permutace o = (5, 3,4, 2, 6,1, 7) se rozkládá na tři cykly (1, 5, 6), (2, 3,4} a (7). Nyní určíme složení a on těchto dvou permutací (už přímo v zápisu cykly):
((1, 5, 6)(2, 3,4}(7}) o ((1, 3, 5, 7, 2,4, 6}) = ((1,4}(2}(3, 6, 5, 7})
(Nezapomínejme, že první se ve složení aplikuje pravá permutace!)
Postup skládání jsme použili následovný: 1 se zobrazí v permutaci vpravo na 3 a pak vlevo na 4. Následně 4 se zobrazí na 6 a pak na 1. Tím „uzavřeme" první cyklus (1,4). Dále se 2 zobrazí na 4 a pak hned zpět na 2, tj. má samostatný cyklus. Zbylý cyklus (3, 6, 5, 7} určíme analogicky. □
6.3 Induktivní definice množin a funkcí
Dalším výkladem se vracíme k podstatě množin a funkcí a k jejich popisu. Vzpomeňme si na definici posloupnosti rekurentním vztahem z Oddílu 3.4. Přímým zobecněním dřívějších rekurentních definic je následující koncept.
Definice 6.5. Induktivní definice množiny.
Jedná se obecně o popis (nějaké) množiny M v následujícím tvaru:
• Je dáno několik pevných (bazických) prvků a±, a2,..., aj- G M.
• Je dán soubor induktivních pravidel typu
Jsoudi (libovolné prvky) x±,... ,xe G M, pak také y G M. V tomto případě je y typicky funkcí y = fi(xi,..., xe).
Pak naše induktivně definovaná množina M je určena jako nejmenší (inkluzí) množina vyhovující těmto pravidlům.
Komentář: Několik ukázek... • Pro nejbližší příklad induktivní definice se obrátíme na množinu všech přirozených čísel, která je formálně zavedena následovně.
- 0 G N
- Je-li i G N, pak také i + 1 G N.
• Pro každé y G N můžeme definovat jinou množinu My C N induktivně takto:
- y G My
- Jestliže x G My a x + 1 je liché, pak x + 2 G My. Pak například M3 = {3}, nebo M4 = {4 + 2i | i G N}.
• Dalším příkladem induktivní definice je už známé zavedení výrokových formulí z Oddílu 1.5. Uměli byste teď přesně říci, co tam byly bázické prvky a jaká byla induktivní pravidla? A jaká byla v definici formulí role přítomných závorek? K tomu se blíže vyjádříme v Definici 6.6.
49
Jednoznačnost induktivních definic
Definice: Řekneme, že daná induktivní definice množiny M je jednoznačná, právě když každý prvek M lze odvodit z bázických prvků pomocí induktivních pravidel právě jedním způsobem.
Komentář: Definujme například množinu M C N induktivně takto:
- 2,3 G M
- Jestliže x, y G M a x < y, pak také x2 + y2 a x ■ y jsou prvky M.
Proč tato induktivní definice není jednoznačná? Například číslo 8 G M lze odvodit způsobem 8 = 2 • (2 • 2), ale zároveň zcela jinak 8 = 22 + 22.
V čem tedy spočívá důležitost jednoznačných induktivních definic množin? Je to především v dalším možném využití induktivní definice množiny jako „základny" pro odvozené vyšší definice, viz následující Definice 6.6 a třeba doplňková Věta 6.9. Stručně a neformálně řečeno, hlavní role jednoznačnosti induktivní definice je v možnosti pak přiřadit prvkům této induktivní množiny nějaký „jednoznačný význam".
Induktivně definovaná množina povětšinou nemá význam sama o sobě, avšak poskytuje defíniční obor pro následnou induktivně definovanou funkci:
Definice 6.6. Induktivní definice funkce z induktivní množiny.
Nechť množina M je dána jednoznačnou induktivní definicí. Pak říkáme, že funkce ÍF :
M —> X je definována induktivně (vzhledem k induktivní definici M), pokud je řečeno:
• Pro každý z bázických prvků ai,a,2,... ,a,k G M je určeno ÍF(ai) = q, kde q je konstanta.
• Pro každé induktivní pravidlo typu
:'Jsou-li (libovolné prvky) x\,..., x p G M, pak také f(x\,..., x e) G M" je definováno
F( f(%i, ■ ■ ■, % e)) na základě hodnot F^Xi),..., F^xi).
Komentář: Ilustrujme si induktivní definici funkce dětskou hrou na „tichou poštu". Definičním oborem je řada sedících hráčů, kde ten první je bázickým prvkem a každý následující (mimo posledního) odvozuje hráče sedícího hned za ním jako další prvek hry. Hodnotou bázického prvku je první (vymyšlené) posílané slovo. Induktivní pravidlo pak následujícímu hráči přiřazuje slovo, které je odvozeno ze („zkomolením") slova předchozího hráče. Výsledkem hry pak je hodnota-slovo posledního hráče.
Pro další příklad se podívejme třeba do manuálových stránek unixového příkazu test EXPRESSION:
EXPRESSION is true or falše and sets exit status. It is one of:
( EXPRESSION ) EXPRESSION is true
! EXPRESSION EXPRESSION is falše
EXPRESSI0N1 -a EXPRESSI0N2 both EXPRESSI0N1 and EXPRESSI0N2 are true
EXPRESSI0N1 -o EXPRESSI0N2 either EXPRESSI0N1 or EXPRESSI0N2 is true
[-n] STRING tne length of STRING is nonzero
STRING1 = STRING2 the strings are equal
Vidíte, jak tato ukázka koresponduje s Definicí 6.6 ? No, ne úplně, poněkud problematická je otázka jednoznačnosti této definice - jednoznačnost není vynucena (jen umožněna) syntaktickými pravidly, jinak je pak dána nepsanými konvencemi implementace příkazu. To je pochopitelně z matematického hlediska velmi špatně, ale přesto jde o pěknou ukázku z praktického života informatika.
50
Induktivní definice se „strukturální" indukcí
Závěrem ještě doplňkově zařazujeme malou ukázku, kterak přirozeně zkombinovat induktivní definice s „pokročilou formou matematické indukce" v dokazování, s tzv. strukturální indukcí.
Příklad 6.7. Jednoduché aritmetické výrazy a jejich význam.
Nechť je dána abeceda E = {0,1, 2, 3,4, 5, 6, 7, 8, 9, 0, ©, (,)}. Definujme množinu jednoduchých výrazů SExp C S* induktivně takto:
- Dekadický zápis každého přirozeného čísla n je prvek SExp.
- Jestliže x,y G SExp, pak také (x) 0 (y) a (x) © (y) jsou prvky SExp.
- Jak vidíme, díky nucenému závorkování je tato induktivní definice jednoduchých výrazů (nikoliv jejich „hodnot") jednoznačná.
Tímto jsme aritmetickým výrazům přiřadili jejich „formu", tedy syntaxi.
Pro přiřazení „významu", tj. sémantiky aritmetického výrazu, následně definujme funkci Val: SExp —> N induktivně takto:
- Bázické prvky: Val(n) = n, kde n je dekadický zápis přirozeného čísla n.
- První induktivní pravidlo: Val((x) © (y)) = Val(x) + Val(y).
- Druhé induktivní pravidlo: Val((x) 0 (y)) = Val(x) ■ Val(y).
Co je tedy správným významem („hodnotou") uvedených aritmetických výrazů? (Příklad 6.8) □
Příklad 6.8. Důkaz správnosti přiřazeného „významu" Val: SExp —> N.
Věta. Pro každý výraz s G SExp je hodnota Val(s) z Příkladu 6.7 číselné rovna výsledku vyhodnocení výrazu s podle béžných zvyklostí aritmetiky.
Jelikož pojednáváme o induktivně definované funkci Val, je přirozené pro důkaz jejích vlastností aplikovat matematickou indukci. Na rozdíl od dříve probíraných příkladů zde nevidíme žádný celočíselný „parametr n", a proto si jej budeme muset nejprve definovat. Naši indukci tedy povedeme podle „délky l odvození výrazu s" definované jako počet aplikací induktivních pravidel potřebných k odvození s G SExp.
Důkaz: V bázi indukce ověříme vyhodnocení bázických prvků, kteréžto jsou zde dekadické zápisy přirozených čísel. Platí Val(n) = n, což skutečně odpovídá zvyklostem aritmetiky.
V indukčním kroku se podíváme na vyhodnocení Val((x) © (y)) = Val(x) + Val(y). Podle běžných zvyklostí aritmetiky by hodnota Val((x) © (y)) měla být rovna součtu vyhodnocení výrazu x, což je podle indukčního předpokladu rovno Val(x) (x má zřejmě kratší délku odvození), a vyhodnocení výrazu y, což je podle indukčního předpokladu rovno Val(y). Takže skutečně Val((x) © (y)) = Val(x) + Val(y).
Druhé pravidlo Val((x) 0 (y)) se dořeší analogicky. □
Dodatek: důkaz pro normální tvar formule
V Oddíle 1.5 jsme stručně zavedli výrokovou matematickou logiku a výrokové formule. Nyní si snadno můžeme všimnout, že jak definice syntaxe, tak i definice sémantiky výrokové logiky jsou induktivní ve smyslu (po řadě) Definic 6.5 a 6.6. Také Metoda 1.18
51
pro převod formule do normálního tvaru je induktivní, a proto je na místě následující ilustrativní ukázka důkazu strukturální indukcí:
Věta 6.9. Pro libovolnou výrokovou formuli ip platí (viz Metoda 1.18), že
a) ÍF(íp) je ekvivalentní formule k ip v normálním tvaru
b) a Q(íp) je formule v normálním tvaru ekvivalentní negaci ~np.
Důkaz povedeme indukcí ke struktuře formule, neboli indukci povedeme podle „délky" l - počtu aplikací induktivních pravidel při sestavování formule ip.
• Báze indukce [l = 0): Pro všechny atomy, tj. výrokové proměnné, zřejmě platí, že ÍF(A) = A je ekvivalentní A a Q (A) = ->A je ekvivalentní —i A.
• V indukčním kroku předpokládejme, že a) i b) platí pro všechny formule ip délky nejvýše l. Vezmeme si formuli ip délky í+1, která je utvořená jedním z následujících způsobů:
* ifj = -np (= je „definiční rovnítko" pro formule). Podle výše uvedeného induktivního předpisu je ÍF(ip) = ÍF(—np) = G(f)- Podle indukčního předpokladu pak je Q(íp) formule v normálním tvaru ekvivalentní ~np = ip. Obdobně pro funktor Q vyjádříme Q(ip) = = ÍF(íp). Podle indukčního předpokladu pak je ÍF(íp) formule v normálním tvaru ekvivalentní 99 a to je dále ekvivalentní -1-199 = —iip podle Tvrzení 1.14.
* ifj = (- ip2). Podle výše uvedeného induktivního předpisuje ÍF(ip) = Fifi =>• if2) = ÍFifi) =>• Jr(^>2)- Podle indukčního předpokladu jsou ÍF(ípi) i ^{^2) formule v normálním tvaru ekvivalentní ipi a • ^{^2) je v normálním tvaru dle definice a podle sémantiky =>- je ta ekvivalentní formuli
{• ¥2) = J^i^i) A G (^2)- Jelikož A je pro nás jen zkratka, výraz dále rozepíšeme G{ip) = ^{^{^1) =^ ~^G{- ip2, což jsme zde měli dokázat.
* ifj = (?i V?2)- Zde si musíme opět uvědomit, že spojka V je pro nás jen zkratka, a přepsat ip = (-1^1 =>• ^2)■ Potom podle předchozích dokázaných případů víme, že ÍF(ip) = ÍF(-^tpi =>• 1P2) = ÍF(-• ^(^2) je ekvivalentní formuli (->• ^2) = ífj, což bylo třeba dokázat. Stejně tak G{ip) = G(~"fi =>• f 2) = ^ľ{~l(-Pi) A G(^2) je podle předchozích případů důkazu ekvivalentní (—upi A -1^2) = ~''lfJ-
* ifj = ( 3 různých vrcholů spojených „do jednoho cyklu" n hranami:
56
Cesta délky n > O má n + 1 různých vrcholů spojených „za sebou" n hranami:
Pn •-•-•-•-•-•
1 2 3 4 • • • n ra + 1
Úplný graf na 77 > 1 vrcholech má n různých vrcholů spojených po všech dvojicích (tj. celkem Q) hran):
4 i 3 l 2
t: 1
6 i í 7?
Úplný bipartitní graf na m > lan > 1 vrcholech má m+77 vrcholů ve dvou skupinách (partitách), přičemž hranami jsou spojeny všechny m ■ n dvojice z různých skupin:
1 2 3 4 ... m V 2' 3' • • • rí
Hvězda s n > 1 rameny je zvláštní název pro úplný bipartitní graf Ki,n:
Definice: Formálně nechť kružnice délky 77 > 3 je graf Cn, kde V(Cn) = {1,2,. ..,77} a E(Cn) = {{i,i + 1} : 1 < i < 77} U {{77,1}}. Nechť cesta délky 77 > 0 je graf Pn, kde \/(Pn) = {1,2,... ,77 + 1} aE(Pn) = {{7,7 + 1} : 1 < i < 77+I}. Nechť úplný graf na 77 > 1 vrcholech je i^, kde V(Kn) = {1, 2,..., 77} a £(Ä„) = {{7, j} : 1 < 7 < j < n}. Nechť úplný bipartitní graf na, m > 1 a 77 > 1 vrcholech je Km,n, kde V(Km,n) = {1,2,... ,m, m+ 1,..., m + 77} a E(Kmjn) = {{7, j} : 1 < 7 < m, m + 1 < j < m + 77}.
Příklad 7.5. Zodpovězte si sami následující otázky:
* Pro jakou hodnotu 77 je úplný graf Kn zároveň cestou?
* Pro jakou hodnotu 77 je úplný graf Kn zároveň kružnici?
* Pro jaké hodnoty m,n > 0 je úplný bipartitní graf Km,n zároveň kružnici?
* Kolik hran musíte přidat do kružnice délky 6, aby vznikl úplný graf na 6 vrcholech?
* Pro jaké hodnoty m,n > 0 úplný bipartitní graf Km,n neobsahuje žádnou kružnici?□
57
Zmínka o zobecněných grafech
Komentář: Všimněme si, že v definici grafu (Def. 7.1) vůbec neuvažujeme možnosti vícenásobných hran (mezi stejnou dvojicí vrcholů) a tzv. „smyček" (hrana se stejným jedním koncem)—takovému zobecnění by se říkalo multigraf; ani zatím nepřisuzujeme hranám žádný směr.
V Lekci 9 si však ještě zavedeme orientované grafy, které každé hraně přiřazují jistý směr. Orientované grafy budou mít množinu orientovaných hran A C V (G) x V (G) a zobrazíme je třeba takto...
7.2 Podgrafy a Isomorfismus
Dva základní nástroje pro práci s grafy jsou následující; možnost popisovat „část grafu" (podobně jako podmnožinu množiny, avšak je nutno se vyvarovat nekorektních situací) a poznávat „stejnost" dvou grafů.
Definice: Podgmfem grafu G rozumíme libovolný graf H na podmnožině vrcholů V(H) C V (G), který má za hrany libovolnou podmnožinu hran grafu G majících oba vrcholy ve V(H).
Píšeme H C G, tj. stejně jako množinová inkluze (ale význam je trochu jiný).
Komentář: Na následujícím obrázku vidíme zvýrazněné podmnožiny vrcholů hran. Proč se vlevo nejedná o podgraf? Obrázek vpravo už podgrafem je.
Definice: Indukovaným podgrafem je podgraf H C G takový, který obsahuje všechny hrany grafu G mezi dvojicemi vrcholů z V(H).
„Stejnost" grafů
Pozorný čtenář si možná již při čtení předchozího oddílu položil otázku: Co když vezmeme jeden graf (třeba kružnici délky 4) a nakreslíme nebo zapíšeme jej jednou tak, podruhé zase jinak - je to stále tentýž graf nebo ne? Viz obrázky dole.
58
Přísně formálně řečeno, každé další nakreslení jistého grafu, třeba této kružnice C4. je jiným grafem, ale přitom bychom rádi řekli, že různá nakreslení téhož grafu jsou „stále stejná". Pro tuto stejnost grafů se vžil pojem isomorfní grafy.
Definice 7.6. Isomorfismus ~ grafů G a H
je bijektivní (vzájemně jednoznačné) zobrazení / : V(G) —> V(H), pro které platí, že každá dvojice vrcholů u,v G V (G) je spojená hranou v G právě tehdy, když je dvojice f(u),f(v) spojená hranou v H.
Grafy G a H jsou isomorfní, pokud mezi nimi existuje isomorfismus. Píšeme G ~ H.
Fakt: Mějme isomorfismus / grafů G a H. Pak platí následující
* G a H mají stejný počet hran,
* / zobrazuje na sebe vrcholy stejných stupňů, tj. de (v) = du(f(v)).
U výše zakreslených dvou grafů objevíme isomorfismus velmi snadno - podíváme se, jak si odpovídají vrcholy stejných stupňů.
Naopak v této trojici grafů (se stejnými počty vrcholů i hran) žádné dva nejsou isomorfní. Proč? Ten vlevo má vrchol stupně 4, čímž se od obou zbylých liší. Prostřední graf pak má jediné dva vrcholy stupně 2 spojené hranou, kdežto v pravém takové dva vrcholy spojené nejsou (isomorfismus by je však i s hranou musel zachovat).
Příklad 7.7. Jsou následující dva grafy isomorfní?
59
Pokud mezi nakreslenými dvěma grafy hledáme isomorfismus, nejprve se podíváme, zda mají stejný počet vrcholů a hran. Mají. Pak se podíváme na stupně vrcholů a zjistíme, že oba mají stejnou posloupnost stupňů 2, 2, 2, 2, 3, 3. Takže ani takto jsme mezi nimi nerozlíšili a mohou (nemusejí!) být isomorfní. Dále tedy nezbývá, než zkoušet všechny přípustné možnosti zobrazení isomorfismu z levého grafu do pravého.
Na levém grafu si pro ulehčení všimněme, že oba vrcholy stupně tři jsou si symetrické, proto si bez újmy na obecnosti můžeme vybrat, že nejlevější vrchol prvního grafu, označme jej 1, se zobrazí na nejlevější vrchol ľ v druhém grafu (taky stupně tři). Očíslujme zbylé vrcholy prvního grafu 2,... ,6 v kladném smyslu, jak je ukázáno na následujícím obrázku. Druhý vrchol stupně tři, označený 4, se musí zobrazit na analogický vrchol druhého grafu (pravý spodní). Pak je již jasně vidět, že další sousedé 2, 6 vrcholu 1 se zobrazí na analogické sousedy 2', 6' vrcholu ľ v druhém grafu, a stejně je to i se zbylými vrcholy 3, 5. Výsledný isomorfismus vypadá v odpovídajícím značení vrcholů takto:
Abychom mohli s isomorfismem grafů přirozeně pracovat, je potřeba vědět následující fakt:
Věta 7.8. Relace „být isomorfní" ~ na třídě všech grafů je ekvivalencí.
Důkaz. Relace ~ je reflexivní, protože graf je isomorfní sám sobě identickým zobrazením. Relace je také symetrická, neboť bijektivní zobrazení lze jednoznačně obrátit. Tranzitivita ~ se snadno dokáže skládáním zobrazení-isomorfismů. □
Důsledkem je, že všechny možné grafy se rozpadnou na třídy isomorfismu. V praxi pak, pokud mluvíme o grafu, myslíme tím obvykle jeho celou třídu isomorfismu, tj. nezáleží nám na konkrétní prezentaci grafu.
Komentář: Je uvedený přístup, tj. zaměňování konkrétního grafu za celou jeho třídu isomorfismu, v matematice neobvyklý? Ne, například už v geometrii jste říkali „čtverec o straně 2" či „jednotkový kruh" a podobně, aniž jste měli na mysli konkrétní obrázek, nýbrž celou třídu všech těchto shodných objektů.
Další grafové pojmy
Definice: Mějme libovolný graf G.
* Podgrafu H C G, který je isomorfní nějaké kružnici, říkáme kružnice v G.
* Speciálně říkáme trojúhelník kružnici délky 3.
* Podgrafu H C G, který je isomorfní nějaké cestě, říkáme cesta v G.
* Podgrafu H C G, který je isomorfní nějakému úplnému grafu, říkáme klika v G. (Někdy se za kliku považuje pouze takový úplný podgraf, který je maximální vzhledem k uspořádání inkluzí.)
60
* Podmnožině vrcholů X C V(G), mezi kterými nevedou v G vůbec žádné hrany, říkáme nezávislá množina X v G.
* Indukovanému podgrafu H C G, který je isomorfní nějaké kružnici, říkáme indukovaná kružnice v G.
Komentář: Uvažujme následující ukázky grafů:
První z ukázaných grafů například neobsahuje žádný trojúhelník, ale obsahuje kružnici délky 4, dokonce indukovanou. Druhý graf trojúhelník obsahuje a kružnici délky 4 taktéž. První graf obsahuje cestu délky 4 na vrcholech 1, 2, 3,4, 5, ale ta není indukovaná. Indukovaná cesta délky 4 v něm je třeba 2,3,4,5,6. Druhý graf tyto cesty také obsahuje, ale naopak žádná z nich není indukovaná. První graf má největší kliku velikosti 2 - jedinou hranu, kdežto druhý graf má větší kliku na vrcholech 3,4, 5. Největší nezávislá množina u obou grafů má 3 vrcholy 2,4, 6.
Fakt: Mějme isomorfismus / grafů G a H. Pokud G obsahuje podgraf F, pak H také musí obsahovat podgraf isomorfní F. Obecněji lze tvrdit, že počet podgrafu v grafu G isomorfních zvolenému F je vždy roven takovému počtu v grafu H.
Příklad 7.9. Jsou následující dva grafy isomorfní?
Postupovat budeme jako v Příkladě 7.7, nejprve ověříme, že oba grafy mají stejně mnoho vrcholů i stejnou posloupnost stupňů 2, 2, 2, 2, 3, 3. Pokud se však budeme snažit najít mezi nimi isomorfismus, něco stále nebude vycházet, že? Co nám tedy v nalezení isomorfismu brání? Podívejme se, že v druhém grafu oba vrcholy stupně tři mají svého společného souseda, tvoří s ním trojúhelník. V prvním grafu tomu tak není, první graf dokonce nemá žádný trojúhelník. Proto zadané dva grafy nejsou isomorfní. □
Poznámka: Výše uvedené příklady nám ukazují některé cesty, jak poznat (tj. najít nebo vyloučit) isomorfismus dvou grafů. Ty však ne vždy musí fungovat. Čtenář se může ptát, kde tedy najde nějaký univerzální postup pro nalezení isomorfismu? Bohužel vás musíme zklamat, žádný rozumný univerzální postup není znám a zatím platí, že jediná vždy fungující cesta pro nalezení či nenalezení isomorfismu mezi dvěma grafy je ve stylu vyzkoušejte všechny možnosti bijekcí mezi vrcholy těchto grafů. (Těch je, jak známo, až n\)
7.3 Souvislost grafů, komponenty
Důležitou globální vlastností grafů je souvislost, tedy možnost se v nich pohybovat odkudkoliv kamkoliv podél jeho hran, neboli po cestách v grafu. Tuto vlastnost si nyní upřesníme.
61
Tvrzení 7.10. Mějme relací ~ na množině vrcholů V(G) libovolného grafu G takovou, že pro dva vrcholy x ~ y právě když existuje v G cesta začínající v x a končící v y. Pak ~ je relací ekvivalence.
Důkaz. Relace ~ je reflexivní, neboť každý vrchol je spojený sám se sebou cestou délky 0. Symetrická je také, protože cestu z x do y snadno v neorientovaném grafu obrátíme na cestu z y do x. Důkaz tranzitivity však není takto triviální—pokud vezmeme cestu z x do y a cestu z y do z, tak se tyto dvě cesty mohou protínat i jinde než v y a nelze je prostě „navázat" na sebe.
Pro důkaz tranzitivity si označme P cestu z x do y a Q cestu z y do z. Pokud označíme P' C P tu část první cesty z x do prvního vrcholu p v průniku s Q (tj. p G V (P) H V (Q)) a označíme Q' ^ Q zbytek druhé cesty od p do z, tak P' U Q' vždy je cestou z x do z. □
Dennice 7.11. Komponentami souvislosti grafu G nazveme
třídy ekvivalence výše popsané (Tvrz. 7.10) relace ~ na V(G). Jinak se také komponentami souvislosti myslí podgrafy indukované na těchto třídách ekvivalence.
Komentář: Podívejte se, kolik komponent souvislosti má tento graf:
Vidíte v obrázku všechny tři komponenty? Jedna z nich je izolovaným vrcholem, druhá hranou (tj. grafem isomorfním K2) a třetí je to zbývající.
Definice 7.12. Graf G je souvislý
pokud je G tvořený nejvýše jednou komponentou souvislosti, tj. pokud každé dva vrcholy G jsou spojené cestou.
Poznámka: Prázdný graf je souvislý a má 0 komponent. Komentář: Který z těchto dvou grafů je souvislý?
Příklad 7.13. Dokažme si, že každý souvislý jednoduchý 2-regulární graf G je kružnicí (tj. isomorfní některé kružnici Cn z Oddílu 7.1).
Nechť e je hranou mezi vrcholy u,v grafu G a vezměme graf G' = G — e vzniklý odebráním hrany e. Pokud by u a v náležely v G' různým komponentám souvislosti, tyto
62
komponenty by každá měla lichý součet stupňů, což nelze podle Věty 7.3. Proto u a, v jsou spojeny cestou v G', nechť vrcholy této cesty jsou po řadě značeny ui = u, u2,... ,Uk = v. Toto značení nám nyní udává isomorfismus zobrazující vrchol u,i na vrchol i z definice kružnice Ck- Nyní už zbývá jen drobnost; dokázat, že jiné vrcholy než u\,... ,Uk v grafu G nejsou. Pokud bychom měli další vrchol x, pak x je spojen cestou Q do u a první vrchol z V(Q) H {ui,..., Uk} by měl stupeň větší než 2, spor. □
7.4 Stromy — grafy bez kružnic
Podrobnější studium některých užitečných aspektů grafů začneme u toho nej jednoduššího typu grafu - na stromech, jež jsou mimo jiné základem mnoha datových typů používaných v informatice.
Komentář:
Charakteristickými znaky stromů je absence kružnic a souvislost...
Definice 7.14. Strom je jednoduchý souvislý graf T bez kružnic.
Komentář: Obecněji les je jednoduchý graf bez kružnic (nemusí být souvislý). Komponenty souvislosti lesa jsou stromy. Jeden vrchol bez hran a prázdný graf jsou také stromy. Grafy bez kružnic také obecně nazýváme acyklické.
Vlastnosti stromů
Přehled základních vlastností stromů je pro nás zároveň příležitostí si ukázat několik nových hezkých matematických důkazů a naučit se správně zdůvodňovat v oblasti grafů.
Tvrzení 7.15. Strom s více než jedním vrcholem obsahuje vrchol stupně 1.
Důkaz: Souvislý graf s více než jedním vrcholem nemůže mít vrchol stupně 0. Proto vezmeme libovolný strom Tav něm libovolný vrchol v. Sestrojíme nyní co nejdelší cestu S v T začínající ve v: S začne libovolnou hranou vycházející z v; v každém dalším vrcholu u, do kterého se dostaneme a má stupeň větší než 1, lze pak pokračovat cestu S další novou hranou.
Pokud by se v S poprvé zopakoval některý vrchol, získali bychom kružnici, což ve stromě nelze. Proto cesta S musí jednou skončit v nějakém vrcholu stupně 1 v T. □
Komentář: Zamyslete se, proč v každém stromě s více než jedním vrcholem jsou alespoň dva vrcholy stupně 1 (odpověď je skrytá už v předchozím důkaze). Zároveň si odpovězte, jestli lze tvrdit, že každý strom s více než jedním vrcholem obsahuje tři vrcholy stupně 1.
63
Věta 7.16. Strom na n vrcholech má přesně n — 1 hran pro n > 1.
Důkaz: Toto tvrzení dokážeme indukcí podle n. Strom s jedním vrcholem má n — 1 = 0 hran. Nechť T je strom na n > 1 vrcholech. Podle Tvrzení 7.15 má T vrchol v stupně 1. Označme T' = T — v graf vzniklý z T odebráním vrcholu -u. Pak T" je také souvislý bez kružnic, tudíž strom na n — 1 vrcholech. Dle indukčního předpokladu T" má n — 1 — 1 hran, a proto T má n — 1 — l + l = n—1 hran. □
Věta 7.17. Mezí každými dvěma vrcholy stromu vede právě jediná cesta.
Jelikož strom T je souvislý dle definice, mezi libovolnými dvěma vrcholy u,v vede nějaká cesta. Pokud by existovaly dvě různé cesty P±,P2 mezi u,v, tak bychom vzali jejich symetrický rozdíl, podgraf H = P1AP2 s neprázdnou množinou hran, kde H zřejmě má všechny stupně sudé. Na druhou stranu se však podgraf stromu musí opět skládat z komponent stromů, a tudíž obsahovat vrchol stupně 1 podle Tvrzení 7.15, což je spor. Proto cesta mezi u a v existuje jen jedna. □
Důsledek 7.18. Přidáním jedné nové hrany do stromu vznikne právě jedna kružnice.
Důkaz: Nechť mezi vrcholy u,v ve stromu T není hrana. Přidáním hrany e = uv vznikne právě jedna kružnice z e a jediné cesty mezi u,v v T podle Věty 7.17. □
Alternativní charakterizace stromů
Z předchozích tvrzení vyplývá následující alternativní charakterizace stromů, která ukazuje důležitost jich samotných i jako tzv. koster obecných grafů (viz Oddíl 8.4).
Na dané množině vrcholů je (vzhledem k inkluzi množin hran) strom
• minimální souvislý graf (plyne z Věty 7.17)
• a zároveň maximální acyklický graf (plyne z Důsledku 7.18).
Jen tak mimochodem, kolik dokážete nalézt neisomorfních stromů na 4 nebo 5 vrcholech? Vidíte, že jich není mnoho? Nakreslete si je všechny.
7.5 Použití a implementace grafů
Závěrem si v našem studijním textu nastíníme některé základní motivace pro zavedení a použití grafů při popisu a řešení problémů například v informatice.
Příklad 7.19. Ukázky některých problémů „ze života" popsatelných grafy. Podotýkáme, že tyto ukázky jsou často velmi zjednodušené (pro jejich lepší přístupnost širokému okruhu čtenářů), ale to neubírá jejich motivačnímu potenciálu.
Důkaz:
N
® v
64
Vyjádření mezilidských vztahů - „mají se rádi", „kamarádí se", „nesnesou jeden druhého", apod:
Zde jednotlivé osoby tvoří vrcholy grafu a vztahy jsou hranami (často neorientované, ale i orientace je přípustná). Všimněme si coby zajímavosti, jak tento model přirozeně preferuje „párový" pohled na vztahy - hrany přece spojují jen dvojice vrcholů. Třebaže například vztah „kamarádí se" může být obecně platný pro větší skupinky lidí než dvojice, stejně se obvykle vyjadřuje klikou v grafu (každí dva v našem družstvu jsou dobří kamarádi...). Tato obecně pojímaná tendence vyjadřovat i složitější vztahy těmi párovými je vodou na mlýn použití teorie grafů jako téměř univerzálního vyjadřovacího prostředku v podobných případech.
Na druhou stranu i teorie grafů disponuje pojmem tzv. hypergmfu umožňujícího použití hran libovolné arity (počtu koncových vrcholů), ale rozsah výskytu hypergrafů v teorii i aplikacích je oproti grafům vskutku zanedbatelný.
Vyjádření závislostí mezi objekty nebo procesy:
Představme si situace, ve kterých jednotlivé entity (modelované jako vrcholy) závisí na výstupech jiných entit a naopak poskytují výstupy další entitám. Typickým příkladem mohou být závislosti jednotlivých kroků výrobního nebo rozhodovacího procesu. Ty pak vedou k definici orientovaného grafu na dané množině vrcholů/entit, tj. použití hran „se šipkami". Všimněme si, že závislosti často bývají časového charakteru (přičemž směr závislosti je implicitně jasný) a pak je nezbytnou doplňkovou podmínkou vyloučení výskytu orientovaných cyklů v modelovém grafu. Na druhou stranu existují i situace, kdy cyklické závislosti jsou dovoleny a mají svůj význam.
Pro ještě jednu ukázku závislostí z běžného života informatika se podíváme na správu balíčků softwaru například v Linuxových distribucích. V tom případě jsou jednotlivé balíčky vrcholy grafu, jejich vyžadované závislosti popisují odchozí hrany a jejich poskytované vlastnosti jsou příchozími hranami grafu závislostí. Korektní instalace zvoleného balíčku pak řeší problém zahrnutí všech dalších vrcholů „dosažitelných" ze zvoleného. Vše je navíc komplikováno správou verzí balíčků, ale to už je mimo rámec našeho úvodního slova.
Modelování technických či dopravních sítí grafy:
V takových případech bývají vrcholy grafu jednotlivá technická zařízení jako třeba rozvodny, routery, křižovatky a podobně, kdežto hrany jsou tvořeny spojnicemi/vedením mezi vrcholy. Často se zde setkáváme s orientovanými grafy a obecně multígrafy. K této problematice se blíže vyjadřuje Lekce 9.
Vizualizace vztahů a závislostí pro lidského pozorovatele:
Nejen při řešení cvičných příkladů v naší učebnici, ale i v mnoha reálných aplikacích využívajících grafy jako modely, je velmi potřebné tyto grafy vizualizovat (tj. hezky nakreslit) pro lidského pozorovatele. Jedná se obecně o poměrně obtížný úkol, který přesahuje hranice našeho textu. n
65
Zpracování grafu počítačem
Mějme jednoduchý graf G na n vrcholech a značme vrcholy jednoduše čísly V(G) = {0,1,... ,n — 1}. Pro počítačovou implementaci grafu G se nabízejí dva základní způsoby které budeme implicitně využívat i v některých algoritmech následujících lekcí.
• Implementace maticí sousednosti, tj. dvourozměrným polem g[][], ve kterém g [i] [j]=l znamená hranu mezi vrcholy i a j.
• Implementace výčtem sousedů, tj. zjednodušeně opět použitím dvourozměrné pole h[] [] a navíc pole d[] stupňů vrcholů. Zde prvky h [i] [0] ,h[i] [1] , . . . ,h[i] [d[i]-l] udávají seznam sousedů vrcholu i.
Poznámka: Dávejte si pozor na symetrii hran v implementaci! To znamená, že pokud uložíte hranu g [i] [j]=l, tak musíte zároveň uložit i hranu g[j] [i]=l, jinak se dočkáte nepříjemných překvapení. Totéž se týká i seznamů sousedů.
Komentář: Implementace maticí sousednosti je hezká svou jednoduchostí. Druhá možnost se však mnohem lépe hodí pro grafy s malým počtem hran, což nastává ve většině praktických aplikací. (Navíc je implementace výčtem sousedů vhodná i pro multigrafy.) Pochopitelně je pak vhodnější místo polí používat různé spojové seznamy. Ke grafům lze do zvláštních polí přidat také ohodnocení vrcholů a hran libovolnými čísly či značkami...
Rozšiřující studium
Grafy můžeme v informatice potkat doslova na každém kroku, mimo jiné hojně už v základních kurzech algoritmizace. Nejen že grafy (především stromy) jsou základem mnoha programátorských datových struktur, ale představují i vhodný model pro spoustu praktických problémů. Oněch pár lekcí teorie grafů v našem učebním textu je jen lehkým úvodem, přičemž na FI MU lze pokračovat v jejím studiu v předmětu MA010.
Rozsáhlý matematický úvod do teorie grafů je zahrnut ve skvělé knize Kapitoly z diskrétní matematiky autorů Jiřího Matouška a Jaroslava Nešetřila. Vřele ji doporučujeme jako doplňkový studijní zdroj všem, kteří chtějí lépe pochopit grafy z jejich matematické stránky.
66
8 Procházení grafu a odvozené úlohy
Úvod
Na rozdíl od předchozí lekce, která se zjednodušeně řečeno zabývala grafy z pohledu matematika, tedy podáním dennice a obrázků, nyní se hlouběji podíváme na grafy z algoritmické či programátorské perspektivy. Proto se v prvé řadě podíváme na obecné schéma procházení grafu, které je základem mnoha užitečných algoritmů na grafech. Poté se hlouběji zaměříme na dvě speciňcké grafové úlohy - hledání nejkratší cesty a minimální kostry, hojně se vyskytující v mnoha praktických obměnách. Na základě obecného schématu si uvedeme jejich jednoduché a velmi efektivní algoritmy.
Cíle
Zjednodušeně podáme obecné schéma algoritmu procházení grafu. Deňnujeme poté dvě konkrétní grafové úlohy, hledání nejkratší cesty mezi dvěma vrcholy a hledání nejmenší kostry, obojí v grafu s hranami ohodnocenými reálnými délkami. Na základě předchozího pak vysvětlíme Dijkstrův algoritmus pro nejkratší cesty a Kruskalův a Jarníkův algoritmus pro minimální kostru.
8.1 Jak obecně projít souvislý graf
S úlohou procházení grafu se svým způsobem setkávají už děti, když hledají cestu z bludiště (jejich naivní postup se dá přirovnat k procházení „do hloubky"). Celý problém má ale mnohem širší záběr a s vhodnou implementací dodatečných lokálních funkcí lze pouhým prohledáním grafu podat odpověď na jiné zajímavé otázky, jako najít nejkratší cestu, minimální kostru, komponenty vyšší souvislosti, apod. Navíc se procházení grafu vyskytuje jako podúloha v jiných algoritmech.
Metoda 8.1. Schéma algoritmu pro procházení grafem
Pro vytvoření co nejobecnějšího schématu si pomůžeme následujícími datovými stavy a pomocnou strukturou:
• Vrchol grafu: má stavy ...
* iniciační - dostane na začátku,
* nalezený - implicitní stav poté, co jsme jej přes některou hranu nalezli (a odložili ke zpracování později),
* zpracovaný - poté, co jsme už probrali všechny hrany z něj vycházející,
* (případně ještě stav „post-zpracovaný", po dokončení všech jeho následníků).
• Úschovna: je pomocná datová struktura (množina s dodatečnými atributy),
* udržuje odložené, tj. nalezené a ještě nezpracované vrcholy, spolu s dodatečnou specifickou informací.
• Postup procházení: zjednodušeně lze říci, že
* nalézáme z vybraných vrcholů jejich sousedy, ukládáme je do úschovny a
* pak zase vybíráme a nalézáme dále dokola, až je vše projito.
• Způsob, kterým se vybírají vrcholy z úschovny ke zpracování, určuje variantu algoritmu procházení grafu.
67
• V prohledávaných vrcholech a hranách se volitelně provádějí dodatečné programové akce pro prohledáni a zpracováni našeho grafu.
Samotný algoritmus pak popíšeme v následujících obecných bodech. (V této souvislosti dodáváme, že podrobněji se budeme způsobu formálního matematického zápisu algoritmů věnovat v Lekci 10, ale zde si vystačíme s běžným jazykem.)
Algoritmus 8.2. Generické procházení souvislé komponenty G grafu
• Vstup: Souvislý graf G, daný seznamem vrcholů a seznamy vycházejících hran z každého vrcholu, plus případné ohodnocení vrcholů a hran.
• Vybereme libovolný počátek prohledávání u G V (G); úschovna U dG(u,w) .
Důkaz. Postupujeme podobně jako v důkaze Tvrzení 7.10 - pokud máme cesty P,P' mezi u,v a mezi v,w, tak existuje cesta Q C P U P' mezi u,w, jež má zřejmě délku nejvýše dG(u,v) + dG(v,w). Skutečná vzdálenost mezi u,w pak už může být jen menší.
□
BFS a zjištění vzdálenosti
Jak nejsnadněji určíme vzdálenost v grafu? Stačí si povšimnout hezkých vlastností procházení grafu do šířky.
Věta 8.7. Algoritmus procházení grafu do šířky lze použít pro výpočet grafové vzdálenosti z daného vrcholu u.
Toto je poměrně jednoduchá aplikace, kdy počátečnímu vrcholu u přiřadíme vzdálenost 0, a pak vždy každému dalšímu nalezenému vrcholu v přiřadíme vzdálenost o 1 větší než byla vzdálenost vrcholu, ze kterého byl nalezen. Důkaz se opírá o následující tvrzení:
* Nechť u,v,w jsou vrcholy souvislého grafu G takové, že dG(u,v) < dG(u,w). Pak při algoritmu procházení grafu G do šířky z vrcholu u je vrchol v nalezen dříve než vrchol w.
Poté přirozeně postupujeme indukcí podle vzdálenosti dG(u,v): Pro dG(u,v) = 0, tj. u = v je tvrzení jasné - vrchol u jako počátek prohledávání byl nalezen první. Proto nechť dG(u,v) = d > 0 a označme v' souseda vrcholu v bližšího k u, tedy de (u, v') = d — 1. Obdobně uvažme libovolného souseda w' vrcholu w. Pak
dG(u, w') > dG(u, w)-l> dG(u, v)-l = dG(u, v'),
a tudíž vrchol v' byl nalezen v prohledávání do šířky dříve než vrchol w' podle indukčního předpokladu. To znamená, že v' se dostal do fronty úschovny dříve než w'. Proto sousedé v' (mezi nimiž je v, ale ne w neboť v'w není hranou) jsou při pokračujícím prohledávání také nalezeni dříve, než w coby soused w'. □
8.3 Hledání nejkratší cesty
V dalším textu se již budeme věnovat grafům s „obecně dlouhými" hranami. Zároveň předesíláme, že přednášená látka stejně dobře může stavět na orientovaných grafech.
Definice: Vážený graf je graf G spolu s ohodnocením w hran reálnými čísly w : E(G) —> R. Kladně vážený graf (G,w) je takový, že w(e) > 0 pro všechny hrany e.
Definice 8.8. (vážená vzdálenost) Mějme (kladně) vážený graf (G,w). Váženou délkou cesty P je
dg(P) = V w(e). Váženou vzdáleností v (G,w) mezi dvěma vrcholy u,v pak je
d'G(u,v) = min{cř^(P) : P je cesta s konci u,v} .
71
Tvrzení 8.9. Vážená vzdálenost v nezáporně vážených grafech (i orientovaných grafech) splňuje trojúhelníkovou nerovnost.
Příklad 8.10. Podívejme se na následující ohodnocený graf (čísla u hran udávají jejich váhy-délky.)
Vzdálenost mezi vrcholy a, c je 3, stejně tak mezi b, c. Co ale mezi a, b! Je jejich vzdálenost 6? Kdepak, vzdálenost a, b je 5, její cesta vede po „horních" vrcholech, jak je vyznačeno. Povšimněte si, že tento příklad zároveň ukazuje, že postup prohledáváním do šířky není korektní pro hledání vzdáleností ve váženém grafu. □
Problém nejkratší cesty
Problém nejkratší cesty mezi dvojicí vrcholů prostě hledá váženou vzdálenost vrcholů a příslušnou cestu. Jedná se patrně o nejznámější „grafový" problém v praktických aplikacích, jenž nalezneme od vyhledávání dopravních spojení, GPS navigací, plánování pohybů robota, až po třeba rozhodovací systémy.
Tento problém se nejčastěji řeší implementací klasického Díjkstrova algoritmu, který je vhodnou úpravou procházení grafu do šířky - vybírá vždy vrchol s nejmenší vzdáleností mezi uschovanými vrcholy.
Dijkstrův algoritmus
Algoritmus 8.11. Hledání nejkratší cesty mezi u a v v kladně váženém grafu.
Tento algoritmus využívá proměnnou hodnotu (pole) d(x) k ukládání nalezených vzdáleností do každého vrcholu x, vedle samotného vrcholu, přičemž tuto hodnotu postupně „vylepšuje" až do finálního zpracování vrcholu.
• Vstup: Souvislý graf G, daný seznamem vrcholů a seznamy vycházejících hran z každého vrcholu, plus váhy w hran. Počáteční vrchol u a koncový v.
• Úschovna U ď(y), odložíme U < 4
1 3 4 4 2 3
3 /
1 / \
1 4 2
Získáme tak minimální kostru velikosti 1 + 2 + 2 + 3 + 1 + 1 + 2 = 12, která je v tomto případě (náhodou) cestou, na posledním obrázku vpravo.
Poznamenáváme, že při jiném seřazení hran stejné váhy by kostra mohla vyjít jinak, ale vždy bude mít stejnou velikost 12.
Věta 8.16. Hladový postup korektně spočítá minimální kostru váženého grafu (G,w).
Důkaz (náznak): Pro spor předpokládejme, že T\ je kostra spočítaná Metodou 8.15 a T2 nějaká minimální kostra, kde cř^(T2) < d^(Ti) a rozdíl \E(T1)AE(T2)\ je nejmenší. Nechť i je nejmenší index takový, že G E(Ti)/\E(T2). Pak nutně G E (Ti) \ E(T2) (proč?), a tudíž T2 + e« podle Důsledku 7.18 obsahuje kružnici procházející také hranou e j pro j > i. Potom však T3 = (T2 + e«) \ {e,-} je další kostrou mající váhu ďQ(T2) + w(e,i) — w(cj) > d^(T2), a proto w(e,i) = w(cj). Tudíž T3 je minimální kostra „bližší" Tí ve smyslu symetrického rozdílu, což je spor s volbou T2. □
75
Jarníkův (Primův) algoritmus
Ač koncepčně velmi jednoduchá, má Metoda 8.15 některé problematické implementační detaily, pro které je mnohem častěji používán následující algoritmus (často připisován Američanu Primoví, ale mnohem dříve publikován Vojtěchem Jarníkem v 1930), založený na běžném procházení grafu.
Algoritmus 8.17. Hledání minimální kostry ve váženém grafu (G,w).
Opět mějme dán souvislý vážený graf G s ohodnocením hran w. Níže uvedená specifická implementace procházení grafu využívá úschovnu rozšířeným způsobem, kdy ukládá i příchozí hranu do vrcholu.
• Vstup: Souvislý graf G, daný seznamem vrcholů a seznamy vycházejících hran z každého vrcholu, plus váhy w hran.
• Vybereme libovolný počátek prohledávání u G V (G); úschovna U w(f). odložíme U 0 je následujícím grafem na n + 1 vrcholech
a orientovaná kružnice (také cyklus) délky n > 1 vypadá takto:
4^3 2
6 ... n
Definice: Počet hran začínajících ve vrcholu u orientovaného grafu D nazveme výstupním stupněm d^,(u) a počet hran končících v u nazveme vstupním stupněm d^u).
Komentář: Součet všech výstupních stupňů je přirozeně roven součtu všech vstupních stupňů orientovaného grafu. Důkaz viz Věta 7.3.
Všimněte si, že některá literatura používá opačná znaménka ( —/+) při značení výstupních a vstupních stupňů, ale s tím nic nenaděláme a čtenář se prostě vždy musí zorientovat a zjistit aktuální situaci.
Definice: Symetrizací orientovaného grafu D rozumíme neorientovaný graf G vzniklý „zapomenutím směru hran" v D, přesněji V(G) = V(D) a uv G E(G) právě když {(u,v),(v,u)}nE(D)r®.
Souvislost na orientovaných grafech
Pojem orientované souvislosti grafu D je natolik fundamentálně odlišný od neorientovaného případu (což je dáno právě jeho „směrovostí"), že si zaslouží samostatnou diskusi i v našem zběžném pohledu na orientované grafy. Uvedeme si na ni odstupňovaně tři základní pohledy:
• Slabá souvislost. Jedná se o tradiční souvislost na symetrizaci grafu D
Komentář: Zjednodušeně a názorně se dá říci, že při cestování grafem „zapomeneme" směr šipek. Na obrázku:
®-2> •-2> • <í-• <í-•-3=-®
Tento přístup sice může vypadat poněkud nesmyslně - proč šipky zavádět a pak zapomínat jejich směr, avšak brzy u tzv. nenasycených cest uvidíme smysl představy, že cesta v orientovaném grafu se „tlačí" proti směru hrany.
79
• Dosažitelnost (směrem „ven"). Orientovaný graf D je dosažitelný směrem ven, pokud v něm existuje vrchol v G V (D) takový, že každý vrchol x G V (D) je dosažitelný orientovaným sledem z v.
V ®-3>
Komentář: Podrobným zkoumáním následujícího obrázku zjistíme, že jeho graf není dosažitelný směrem ven, neboť chybí možnost dosáhnout vrchol b úplně vpravo. Na druhou stranu po vypuštění b je zbylý graf dosažitelný ven z vrcholu a vlevo.
• Silná souvislost. Nechť »2 je binární relace na vrcholové množině V(D) orientovaného grafu D taková, že u ~ v právě když existuje dvojice orientovaných cest - jedna z u dowa druhá z v do u v grafu D. Pak »2 je relace ekvivalence.
Definice 9.2. Silné komponenty orientovaného grafu D
jsou třídy ekvivalence relace »2 uvedené v předchozím. Orientovaný graf D je silně souvislý pokud má nejvýše jednu silnou komponentu.
Komentář: Pro ilustraci si mírně upravíme dříve prezentovaný orientovaný graf tak, že bude dosažitelný z nejlevějšího vrcholu. Je výsledek silně souvislý?
Ne, na obrázku jsou vyznačené jeho 4 silné komponenty. Vpravo zároveň uvádíme pro ilustraci obrázek kondenzace silných komponent tohoto grafu, což je acyklický orientovaný graf s vrcholy reprezentujícími zmíněné silné komponenty a směry hran mezi nimi.
Pro zvídavé čtenáře poznamenáváme, že si mohou definici silné komponenty porovnat s jádrem předuspořádání v Oddíle 5.4. Kde vidíte drobný rozdíl?
80
9.2 Definice sítě a toku
Základní strukturou pro reprezentaci sítí je vážený orientovaný graf (přičemž implicitní směr hran je v tomto kontextu nezbytný). Váhy (hran) v takovém modelu vyjadřují „kapacity" jednotlivých spojů a nás zajímá, jak mnoho uvažované substance dokážeme (různými cestami) přenést z daného zdroje do stoku. Podstata substance není důležitá, ale ta musí být vhodně rozdělitelná.
Definice 9.3. Síť je čtveřice S = (D,z,s,w), kde
* D je orientovaný graf,
* vrcholy z G V (D), s G V (D) jsou zdroj a stok,
* w : E(D) —> R+ je kladné ohodnocení hran, zvané kapacita hran.
Na obrázku je zakreslena síť s vyznačeným zdrojem z a stokem s, jejíž kapacity hran jsou zapsány čísly u hran. Šipky udávají směr hran, tedy směr proudění uvažované substance po spojnicích. Pokud směr proudění není důležitý, vedeme mezi vrcholy dvojici opačně orientovaných hran se stejnou kapacitou. Kapacity hran pak omezují maximální množství přenášené substance.
Poznámka: V praxi může být zdrojů a stoků více, ale v definici stačí pouze jeden zdroj a stok, z něhož / do nějž vedou hrany do ostatních zdrojů / stoků. (Dokonce pak různé zdroje a stoky mohou mít své kapacity.)
Velikost toku v síti
V souladu s praktickými aspekty nás u toku v síti zajímá především to, jaké „množství" substance (velikost toku) se skutečně přenese od zdroje ke stoku.
Značení: Pro jednoduchost píšeme ve výrazech značku e —y v pro hranu e končící ve vrcholu v a e splňující
* Ve G E (D) : 0 < f (e) < w(e),
* Vv(=V(D),vŕz,s: E/(e)= E /(e)-
Velikost toku / je dána výrazem ||/|| = E f(e) ~ E f(e)-
e<—z e—>z
Značení: Tok a kapacitu hran v obrázku sítě budeme zjednodušeně zapisovat ve formátu F/C, kde F je hodnota toku na hraně a C je její kapacita.
81
Komentář: Neformálně tok znamená, kolik substance je každou hranou zrovna přenášeno (ve směru této hrany, proto hrany musí být orientované). Tok je pochopitelně nezáporný a dosahuje nejvýše dané kapacity hrany. Navíc je nutno v každém vrcholu mimo z, s splnit podmínku „zachování substance".
Ve vyobrazeném příkladě vede ze zdroje vlevo do stoku vpravo tok o celkové velikosti 5.
Poznámka: Obdobně se dá velikost toku definovat u stoku (či i na obecném řezu v síti, viz dále), neboť platí následující identita odvozená z vlastnosti zachování substance v definici toku
o = £ (/w - /(«)) = £ í £ m - E /(«)) = E í E ^ - E ^
edE vdV \e<— v e—>u J v=z,s \e<— v e—>v
Proto velikost toku počítaná u zdroje je rovna opačné velikosti toku počítaného u stoku
(£/(«)-£/(«)) = (£/(«)-£/(«)
\e<— z e—>z / \e—>s e-(—s
9.3 Nalezení maximálního toku
Naším úkolem je najít co největší přípustný tok v dané síti. Pro jeho nalezení existují jednoduché a velmi rychlé algoritmy. Navíc tyto algoritmy mají zajímavé teoretické souvislosti a důsledky uvedené později.
Definice 9.5. Úloha hledání maximálního toku v síti S = (D,z,s,w).
Úkolem je v síti S najít tok / ze zdroje z do stoku s podle Definice 9.4 takový, který
maximalizuje velikost ||/||.
Komentář: Tok velikosti 5 uvedený v ukázce v předchozí části nebyl optimální, neboť v této síti najdeme i tok velikosti 6:
Jak však poznáme, že větší tok již v dané síti neexistuje? V této konkrétní ukázce to není obtížné, vidíme totiž, že obě dvě hrany přicházející do stoku mají součet kapacit 2+4 + 6, takže více než 6 do stoku ani přitéct nemůže. V obecnosti lze použít obdobnou úvahu, kdy najdeme podmnožinu hran, které nelze tokem „obejít" a které v součtu kapacit dají velikost našeho toku. Existuje však taková množina hran vždy? Odpověď nám dá následující definice a věta.
82
Pojem řezu v síti
Dennice 9.6. Rez v síti S = (D, z, s, w) je podmnožina hran X C E (D)
taková, že v podgrafu D — X (tj. po odebrání hran X z D) nezbude žádná orientovaná
cesta ze z do s. Velikostí řezu X rozumíme součet kapacit hran z X, tj. ||X|| = /\,eeX w(e).
Zcela klíčovým poznatkem síťových úloh je následující velmi hezká charakterizace jejich optimálního řešení
Věta 9.7. Maximální velikost přípustného toku v síti je vždy rovna minimální velikosti řezu v ní.
Komentář: Na následujícím obrázku vidíme trochu jinou síť s ukázkou netriviálního minimálního řezu velikosti 5, naznačeného svislou čárkovanou čarou. Všimněte si dobře, že definice řezu mluví o přerušení všech orientovaných cest ze z do s, takže do řezu stačí započítat hrany jdoucí přes svislou čáru od z do s, ale ne hranu jdoucí zpět. Proto je velikost vyznačeného řezu 1+4 = 5.
Důkaz Věty 9.7 bude proveden následujícím Algoritmem 9.9.
Nenasycené cesty v síti
Definice: Mějme síť S a v ní tok /. Nenasycená cesta P (v S vzhledem k /) je neorientovaná cesta v D mezi určenými vrcholy (obvykle ze z do s), tj. posloupnost navazujících libovolně orientovaných hran e±, e2,..., em, kde /(e^) < w(cí) pro e« ve směru ze z do s a f(cj) > 0 pro e j v opačném směru.
Hodnotě w(cí) — /(e^) > 0 pro hrany ve směru z u do v a hodnotě f(cj) > 0 pro hrany e,- v opačném směru říkáme rezerva kapacity hran. Nenasycená cesta je tudíž cesta s kladnými rezervami kapacit všech hran.
Komentář: Zde vidíme příklad nenasycené cesty ze zdroje do stoku s minimální rezervou
kapacity +1.
rezerva kapacity:
1/2 1/1
+1 +1
+1
2/3
+2 +2
> o
Všimněte si dobře, že cesta není orientovaná, takže hrany na ní jsou v obou směrech.
Metoda 9.8. Maximální tok vylepšováním nenasycených cest.
Základní myšlenkou této jednoduché metody hledání maximálního toku v dané síti je prostě opakovaně vylepšovat tok podél nalezených nenasycených cest.
83
Komentář: Ve výše zakresleném obrázku nenasycené cesty byla minimální rezerva kapacity ve výši +1, a tudíž nasycením této cesty o velikost toku 1 vzniká následující fragment přípustného toku v síti:
Zajímavé je se podívat, co se stalo s prostředními zpětně orientovanými hranami - fakticky byl jejich zpětný tok o 1 snížen/zastaven, přičemž toto množství nyní „teče doprava" (velmi neformálně řečeno).
Fakt: Je-li minimální rezerva kapacity hran nenasycené cesty P ze z do s ve výši r > 0, pak tok ze z do s zvýšíme o hodnotu r následovně:
* pro hrany G E (P) ve směru ze z do s zvýšíme tok na /'(e^) = f(eí) + r-
* pro hrany e,- G E (P) ve směru ze s do z snížíme tok na /'(e,) = /(e,) — r. Výsledný tok /' pak bude opět přípustný.
Základní algoritmus nenasycených cest
Rámcové implementační podrobnosti Metody 9.8 následují v popise konkrétního algoritmu.
Algoritmus 9.9. Ford-Fulkersonův pro tok v síti.
* Vstup: Síť S = (D,z,s,w) podle Definice 9.3.
• Dále opakujeme následující:
* Prohledáváním grafu najdeme množinu U vrcholů D, do kterých se dostaneme ze z po nenasycených cestách.
* Pokud s G U, nechť P značí nalezenou nenasycenou cestu v S ze z do s.
- Zvětšíme tok / o minimální rezervu kapacity hran v P.
• Opakujeme kroky výše, dokud nenastane s U.
• Výstup: Vypíšeme maximální tok / a také minimální řez jako množinu všech hran vedoucích z U do V(D) — U.
Příklad 9.10. Ukázka průběhu Algoritmu 9.9
Následují obrázky jednotlivých kroků algoritmu, kde vždy levý obrázek zvýrazní nenasycenou cestu a vpravo se nasycením zvýší celkový tok.
4/4 2/2 0/1 1/3 3/4
. Tok f U (přicházející do U) tok /(e) = 0, takže
E /(e) - E /(e) = E /(e) = E»(e) = 11*11 ■
Na druhou stranu, když v sumě uvažujeme všechny hrany grafu indukované na naší množině U, tj. e G i?(Z) f U), analogicky dostaneme požadované
o= E (/(^)-/(e)) = EÍE/(e)-E/(e))-ÍE/(e)-E/(e)
eeE(D\U) velí \e^v e-^v / \e^U e^U
\e^z e—>z / \e^U e—>U
\x\\ , tj. lun = ||X||.
□
Z důkazu Algoritmu 9.9 pak odvodíme několik zajímavých faktů:
Fakt: Pokud zajistíme, že Algoritmus 9.9 vždy skončí, zároveň tím dokážeme i platnost Věty 9.7.
Fakt: Pro celočíselné kapacity hran sítě S Algoritmus 9.9 vždy skončí.
Fakt: Existují snadná vylepšení Algoritmu 9.9 (jako Edmonds-Karp či Dinitz), u kterých je zaručeno, že výpočet vždy skončí. Obecně k dosažení tohoto cíle postačí vždy uvažovat pouze nejkratší nenasycené cesty, což je ale mimo dosah našeho kurzu.
Pro další využití v teorii grafů je asi nej důležitější tento poznatek:
Důsledek 9.11. Pokud jsou kapacity hran sítě S celočíselné, optimální tok také vyjde celočíselně.
Důkaz: Postupujeme jednoduchou indukcí podle iterací Algoritmu 9.9: Algoritmus začíná s celočíselným tokem 0. V každé další iteraci bude na počátku tok všemi hranami celočíselný, tudíž i rezervy kapacit hran vyjdou (rozdílem od celočíselné kapacity) celočíselně. Proto i hodnoty toku budou změněny jen celočíselně, což zakončuje indukční krok. □
9.4 Zobecněné použití sítí
Pojmy sítě a toků v ní lze v kombinatorické optimalizaci zobecnit a využít několika směry. My si zde stručně uvedeme následující možnosti.
• Sítě s kapacitami vrcholů:
U sítě můžeme zadat kapacity vrcholů, neboli kapacitní váhová funkce je dána jako w : E(D) U V (D) —> R+. Takovou síť „zdvojením" vrcholů snadno převedeme na běžnou síť, ve které kapacity původních vrcholů budou uvedeny u nových hran spojujících
86
• Sítě s dolními kapacitami:
Pro hrany sítě lze zadat také jejich minimální kapacity, tedy dolní meze přípustného toku, jako váhovou funkci l : E(D) —> Rq". Přípustný tok pak musí splňovat l(e) < /(e) < w(e) pro všechny hrany e. V této modifikaci úlohy již přípustný tok nemusí vůbec existovat, takže postup řešení musí zavést počáteční fázi, ve které se nějaký tok splňující minimální kapacity nalezne vhodnou úpravou zadané sítě. Poté se pokračuje metodou nenasycených cest.
Bipartitní párování
Bipartitní grafy jsou grafy, jejichž vrcholy lze rozdělit do dvou množin tak, že všechny hrany vedou jen mezi těmito množinami, neboli podgrafy úplných bipartitních grafů.
Definice: Párovánív (nyní bipartitním) grafu G je podmnožina hran M C E (G) taková, že žádné dvě hrany z M nesdílejí koncový vrchol.
Komentář: Úlohu nalézt v daném bipartitním grafu co největší párování lze poměrně snadno vyřešit pomocí toků ve vhodně definované síti. Uvedená metoda použití toků v síti na řešení problému párování přitom hezky ilustruje obecný přístup, jakým toky v sítích pomohou řešit i úlohy, které na první pohled se sítěmi nemají nic společného.
Metoda 9.12. Nalezení bipartitního párování
Pro daný bipartitní graf G s vrcholy rozdělenými do množin A, B sestrojíme síť S následovně:
1
• Všechny hrany sítě S orientujeme od zdroje do stoku a přiřadíme jim kapacity 1.
• Nyní najdeme (celočíselný) maximální tok v S Algoritmem 9.9. Do párování vložíme ty hrany grafu G, které mají nenulový tok.
87
Důkaz správnosti Metody 9.12: Podle Důsledku 9.11 bude maximální tok celočíselný, a proto každou hranou poteče buď 0 nebo 1. Jelikož však do každého vrcholu v A může ze zdroje přitéct jen tok 1, bude z každého vrcholu A vybrána do párování nejvýše jedna hrana. Stejně tak odvodíme, že z každého vrcholu B bude vybrána nejvýše jedna hrana, a proto vybraná množina skutečně bude párováním. Zároveň to bude největší možné párování, protože z každého párování lze naopak vytvořit tok příslušné velikosti a větší než nalezený tok v S neexistuje. □
Poznámka: Popsaná metoda je základem tzv. Maďarského algoritmu pro párování v bipartitních grafech. Úlohu nalezení maximálního párování lze definovat i pro obecné grafy a také ji efektivně algoritmicky vyřešit, ale příslušný algoritmus [Edmondsův] není jednoduchý.
Výběr různých reprezentantů
Definice: Nechť M1,M2,...,Mk jsou neprázdné množiny. Systémem různých reprezentantů množin M1,M2,...,Mk nazýváme takovou posloupnost různých prvků (x1,x2,... ,xk), že Xi G Mi pro i = 1, 2,..., k.
Důležitým a dobře známým výsledkem v této oblasti je Hallova věta plně popisující, kdy lze systém různých reprezentantů daných množin nalézt.
Věta 9.13. Nechť M\, M2,..., Mk jsou neprázdné množiny. Pro tyto množiny existuje systém různých reprezentantů, právě když platí
VJC{l,2,...,fc}: IM Mj
> \ J\
neboli pokud sjednoceni libovolné skupiny z těchto množin má alespoň tolik prvků, kolik množin je sjednoceno.
Důkaz: Označme x\, x2,..., xm po řadě všechny prvky ve sjednocení M\VJM2\J- ■ -UM^. Definujeme si bipartitní graf G na množině vrcholů {1,2,..., k}\j{x\,x2,..., xm}U{u, v}, ve kterém jsou hrany {u, i} pro i = 1, 2,..., k, hrany {v, Xj} pro j = 1, 2,..., m a hrany {i,Xj} pro všechny dvojice i,j, pro které x j G Mj.
Komentář: Konstrukce našeho grafu G je obdobná konstrukci sítě v Metodě 9.12: Vrcholy u a v odpovídají zdroji a stoku, ostatní hrany přicházející do vrcholu x j znázorňují všechny z daných množin, které obsahují prvek Xj.
Cesta mezi u a v má tvar u, i, Xj,v, a tudíž ukazuje na reprezentanta x j G Mj. Systém různých reprezentantů tak odpovídá k disjunktním cestám mezi u a, v. Nechť X je nyní libovolná minimální^ množina vrcholů v G, neobsahující samotné u a v, po jejímž odebrání z grafu nezbude žádná cesta mezi u a, v. Podle této úvahy mají naše množiny systém různých reprezentantů, právě když každá taková oddělující množina X má aspoň k prvků.
Položme J = {1, 2,..., k} \ X. Pak každá hrana z J (mimo u) vede do vrcholů z V H {xi,..., xm} (aby nevznikla cesta mezi u,v), a proto
|l I Mj =\XC\{x1,...,xm}\ = \X\-\XC\{l,...,k}\ = \X\-k+\J\.
(První rovnost vyplývá z minimality množiny X.) Vidíme tedy, že |X| > k pro všechny (minimální) volby oddělující X, právě když \J-eJMj > \J\ pro všechny volby J, což je dokazovaná podmínka naší věty. □
88
Poznámka: Tento důkaz nám také dává návod, jak systém různých reprezentantů pro dané množiny nalézt - stačí použít Algoritmus 9.9 na vhodně odvozenou síť.
Rozšiřující studium
Orientované grafy v obvyklých učebnicích teorie grafů mnoho místa nemají a speciálně v češtině není mnoho zdrojů věnujících se přímo orientovaným grafům. Mnohé aspekty grafů (včetně některých grafových algoritmů) však zůstávají stejné i v orientovaném podání, jak můžeme vidět třeba v otázkách isomorňsmu či hledání nejkratší cesty. Otázky síťových toků a silné souvislosti studované v této lekci však dostávají na orientovaných grafech "nový rozměr"nemající v neorientovaných grafech rozumné obdoby - pro ně je směr hran podstatný. My se zde hlouběji orientovanými grafy nezabýváme, ale zájemce odkazujeme především na algoritmické zdroje a kurzy, neboť úloha síťových toků je jednou ze základních praktických úloh kombinatorické optimalizace.
89
10 Formalizace a důkazy pro algoritmy
Úvod
Po předchozí převážně matematické látce se náš výklad obrací bezprostředně k informatice. Mnozí z vás si asi již všimli, že umění programovat není zdaleka jen o tom naučit se syntaxi programovacího jazyka, ale především o schopnosti vytvářet a správně formálně zapisovat algoritmy. Přitom třeba situace, kdy programátorem zapsaný kód ve skutečnosti počítá něco trochu jiného, než si autor představuje, je snad nejčastější programátorskou chybou - o to zákeřnější, že ji žádný „chytrý" překladač nemůže odhalit.
Proto již na počátku studia informatiky je žádoucí klást důraz na správné chápání zápisu algoritmů i na přesné důkazy jejich vlastností a správnosti. A to je téma, kterému se budeme věnovat následující dvě lekce.
Cíle
Bude zaveden způsob formálního zápisu algoritmů pro potřeby dalšího výkladu, nezávisle na konkrétních programovacích jazycích. Na tomto formalismu pak bude ukazováno správné chápání chování algoritmů a příklady důkazů na konkrétních „malých" algoritmech. Nejdůležitější technikou důkazů bude matematická indukce. Na druhou stranu je třeba dodat, že uváděné algoritmy jsou pouze bezvýznamné ilustrativní ukázky pro cvičení důkazů a není úkolem tohoto textu učit čtenáře návrhu algoritmů.
10.1 Formální popis algoritmu
Před samotným závěrem našeho matematického kurzu si položme klíčovou otázku, co je vlastně algoritmus? Když se na tím zamyslíte, asi zjistíte, že to není tak jednoduché přesně říci. Dokonce je to natolik obtížná otázka, že si zde můžeme podat jen docela zjednodušenou (či naivní?) odpověď, přesto však dostatečnou pro zamýšlenou demonstraci matematických důkazů pro běžné algoritmy.
Poznámka: Za definici algoritmu je obecně přijímána tzv. Church-Turingova teze tvrdící, že všechny algoritmy lze „simulovat" na Turingově stroji. Jedná se sice o přesnou, ale značně nepraktickou definici. Mimo Turingova stroje existují i jiné matematické modely výpočtů, jako třeba stroj RAM, který je abstrakcí skutečného strojového kódu, nebo také třeba tzv. neprocedurální (neimperativní) modely zahrnující funkcionální a logické programování.
Konvence 10.1. Zjednodušeně zde algoritmem rozumíme konečnou posloupnost elementárních výpočetních kroků, ve které každý další krok vhodné1 využívá (neboli závisí na) vstupní údaje či hodnoty vypočtené v předchozích krocích. Tuto závislost přitom pojímáme zcela obecně nejen na operandy, ale i na vykonávané instrukce v krocích.
Pro zápis algoritmu a jeho zpřehlednění a zkrácení využíváme řídící konstrukce -podmíněná větvení a cykly.
Komentář: Vidíte, jak blízké si jsou konstruktivní matematické důkazy a algoritmy v našem pojetí? Jedná se nakonec o jeden ze záměrů našeho přístupu...
1Zvídaví studenti si mohou na tomto místě uvědomit, že ve slůvku „vhodně" se skrývá celá hloubka Church-Turingovy teze. V žádném případě tak nelze mechanicky bez zamyšlení obracet, že by každá posloupnost kroků atd ... byla algoritmem ve smyslu této teze (viz také Lekce 12).
90
Příklad 10.2. Zápis algoritmu pro výpočet průměru daného pole a[] s n prvky. Algoritmus.
• Inicializujeme sum 0 :
• postupně pro i=0,l,2, . . . ,n-l provedeme
* sum sum+a[i] :
• vypíšeme podíl (sum/n) . □
Ve „vyšší úrovni" formálnosti (s jasnějším vyznačením elementárních kroků a řídících struktur algoritmu) se totéž dá zapsat jako:
Algoritmus 10.3. Průměr z daného pole a[] s n prvky.
input pole a [] délky n; sum 0;
foreach i 0,1,2, . . . ,n-l do sum sum+a[i] ;
done
res sum/n; output res;
Symbolický zápis algoritmů
Značení. Pro potřeby symbolického formálního zápisu algoritmů v předmětu FI: IB000 si zavedeme následující pravidla:
* Proměnné nebudeme deklarovat ani typovat, pole odlišíme závorkami p[].
* Přiřazení hodnoty zapisujeme a 0 vypočítáme x-té Fibonacciho číslo následovně:
if x < 2 then t x;
else t íibonacci(x-l)+íibonacci(x-2); return t
Komentář: Správnost Algoritmu 10.13 je víceméně zřejmá z jeho přímé podoby s rekurentním vzorcem v definici Fibonacciho čísel. Zamyslete se však, jak je to s praktickou „proveditelností" takového algoritmu... Vidíte (případně si zkuste naprogramovat), že čas výpočtu roste velmi rychle? Třebaže hodnotu fibonacci(30) tímto algoritmem spočítáte poměrně rychle, s výpočtem fibonacci(40) už budete mít větší problémy a fibonacci(50) asi bude mimo vaše možnosti. To skutečně není dobrý algoritmus! Podívejte se také na budoucí Příklad 11.5, který odhaduje, jak mnoho (exponenciálně) kroků výpočtu je potřeba.
Proto si v dalším Příkladu 10.14 uvedeme poněkud (ve skutečnosti velmi výrazně) lepší algoritmus výpočtu, podobající se přirozenému lidskému postupu psaní členů posloupnosti „do řádku na papír". Doporučujeme si oba algoritmy zkusit implementovat a mezi sebou porovnat.
Příklad 10.14. Nerekurzivní algoritmus pro Fibonacciho čísla.
Dokažte, že následující algoritmus pro každé přirozené n počítá tutéž hodnotu jako rekurentní funkce fibonacci(n) v Algoritmu 10.13 (ale mnohem mnohem rychleji).
Algoritmus . input n;
b[0] <- 0; b[l] <- 1; foreach i 2,3, . . . ,n do b [i] 2 předpokládáme platnost indukčního předpokladu b[j] = fibonacci(j) pro j G {i — 1, i — 2}. V i-té iteraci cyklu pak nastane b[i] b[i — 1] + b[i — 2] = j'ibonacci(i — 1) + j'ibonacci(i — 2) = fibonacci(i) podle definice. Tím je důkaz hotov pro hodnotu i = n. □
95
Rozšiřující studium
Náš výklad pohlíží na algoritmy a programování tzv. procedurálním neboli imperativním paradigmatem. Vedle toho existují i jiné přístupy k programování, jako zmíněné funkcionální nebo logické. Na FI se s jinými přístupy studenti seznámí třeba v předmětu Neimperativní programování. Pro náš předmět však výběr výpočetního paradigmatu není nejdůležitější.
Smyslem této lekce bylo především ukázat, že u jednoduchých algoritmů lze (a je vhodné) je matematicky formálně zapisovat i dokazovat jejich správnost. Samozřejmě je iluzorní předpokládat, že obdobné důkazy správnosti podáme i pro velké softwarové projekty čítající až milióny řádků, ale postupy a techniky naučené při ověřování jednoduchých algoritmů s úspěchem využijete i při kontrole a ladění jednotlivých kousků velkých projektů.
O mnoha různých pokročilých technikách formální verifikace programů se v případě zájmu dozvíte v pokračujícím studiu. Tyto techniky jsou schopny na vhodném „modelu" rutinně a matematicky přesně ověřovat (ne)existenci mnoha běžných programátorských chyb.
96
11 Pokročilé dokazování nad algoritmy
Úvod
Přímo navazujeme na Lekci 10 a pokračujeme v ukázkách matematického dokazování nad vybranými krátkými algoritmy Výklad již bude trochu náročnější a místo uměle přichystaných (a v podstatě triviálních) příkladů se budeme věnovat i několika obecným dobře známým algoritmům. Dá se říci, že tato lekce je „vrcholem" v naší snaze o matematické dokazování algoritmů v informatice. Soustřeďte se v ukázkách důkazů na pochopení, jak jednotlivé formální matematické kroky korespondují s průběhem algoritmů.
Cíle
Naší snahou v těchto dvou lekcích je čtenáři ukázat poměrně vyčerpávající přehled způsobů a triků, které lze využít k analýze a dokazování správnosti rozumně krátkých algoritmů. Tyto poznatky by měly základem toho, aby si čtenář jako programátor uměl po sobě své algoritmy „přečíst" a ověřit jejich skutečnou správnost na lokální úrovni.
11.1 Dokazování konečnosti algoritmu
Co bývá snad ještě horší, než chybný výsledek algoritmu? Je to situace, kdy spuštěný algoritmus běží „do nekonečna" a vůbec se nezastaví.
Komentář: Všimněte si, že jsme se zatím v důkazech Lekce 10 vůbec nezamýšleli nad tím, zda naše algoritmy vůbec skončí. (To není samozřejmé a důkaz konečnosti je nutno v obecnosti podávat!) Prozatím jsme však ukazovali algoritmy využívající jen foreach cykly, přitom podle naší konvence obsahuje foreach cyklus předem danou konečnou množinu hodnot pro řídící proměnnou, neboli náš foreach cyklus vždy musí skončit. Ale už v příštím algoritmu využijeme while cyklus, u kterého vůbec není jasné kdy a jestli skončí, a tudíž bude potřebný i důkaz konečnosti.
Právě nad takovou situací a její možnou prevencí se v tomto oddíle zamyslíme. Předesíláme, že další podnětná látka k témuž tématu se nachází ještě v Lekci 12.
Příklad 11.1. Zastaví se vždy výpočet následujícího primitivního algoritmu? Algoritmus 11.2. input x; while x>5 do x 5. Nechť přirozené n > 5 je zvoleno tak, že Algoritmus 11.2 skončí pro x = n po nejmenším možném počtu l průchodů cyklem while.
Pak jistě l > 0, neboť na začátku je podmínka x>5 splněna z definice n. Po prvním průchodu pak x = n + 1 > 5, avšak nyní již Algoritmus 11.2 musí skončit po l — 1 < l dalších průchodech cyklu. To je spor s volbou x = n coby vstupní hodnoty s nejmenším
97
možným počtem průchodů (pro x = n + 1 totiž do ukončení výpočtu proběhne o jeden průchod méně - o ten jeden vykonaný na začátku naší úvahy). □
Když algoritmus vždy končí
Na rozdíl od předchozí ukázky se budeme dále věnovat pozitivním případům, kdy algoritmy poslušně končí své výpočty.
Metoda 11.3. Jednoduchý důkaz konečnosti.
Máme-li za úkol dokázat, že algoritmus skončí, vhodný postup je následující:
* Sledujeme zvolený celočíselný a zdola ohraničený parametr algoritmu (třeba přirozené číslo) a dokážeme, že se jeho hodnota v průběhu algoritmu neustále ostře zmenšuje.
* Případně předchozí přístup rozšíříme na zvolenou k-tici přirozených parametrů a dokážeme, že se jejich hodnoty v průběhu algoritmu lexikograficky ostře zmenšují.
Jedná se zde vlastně o vhodné (a zjednodušené pro daný účel) využití principu matematické indukce. Pozor, naše „parametry" vůbec nemusejí být proměnnými v programu, a přesto jsou s programem implicitně nerozlučně svázány.
Komentář: Například pro rekurzivní funkci factorial(x) z Příkladu 10.12 přímo využijeme parametr x, který se ostře zmenšuje, pro snadný důkaz ukončenosti.
Zamyslíme-li se nad Metodou 11.3 do hloubky (matematické), zjistíme, že stejně jako matematická indukce je založená na této vlastnosti: V každé podmnožině přirozených čísel existuje jedno nejmenší (tomu se říká dobré uspořádání). Proto garance zmenšování přirozené hodnoty parametru algoritmu prostě musí znamenat ukončenost jeho výpočtu, bez ohledu na to, co náš vymyšlený parametr znamená. Nejlépe je to ilustrovat názornými příklady.
Příklad 11.4. Dokažte, že následující algoritmus vždy skončí pro jakýkoliv přirozený vstup x.
Algoritmus .
input x;
while x<100 do
y 0 a v každém průchodu vnějšího i vnitřního cyklu se p(x, y) ostře zmenší. Čtenář nechť si toto ověří sám. □
98
Příklad 11.5. Dokažte, že následující algoritmus (viz dřívější 10.13) vždy skončí pro jakýkoliv přirozený vstup x.
Algoritmus . Rekurzivní výpočet funkce fibonacci(x) pro přirozené x. if x < 2 then t x;
else t íibonacci(x-l)+íibonacci(x-2); return t
Nyní je na první pohled přirozené sledovat přímo parametr x. Indukcí podle něj pak snadno odvodíme, že výpočet fibonacci(x) vždy skončí, neboť jsou rekurzivně volány jen menší hodnoty parametru. V čem je tedy možný nedostatek tohoto přímého přístupu? V zásadě pouze jediný; nezískáme z něj žádný rozumný horní odhad počtu kroků algoritmu. Pro vysvětlení, problém spočívá zhruba v tom, že v bodě íibonacci(x-l)+íibonacci(x-2) se výpočet „rozvětvuje" a my musíme vhodným způsobem umět sečíst počty kroků obou větví.
Na druhou stranu při trikové volbě parametru p(x) = 2X pro použití Metody 11.3 v každé iteraci rekurzivního volání fibonacci(x) pro x >2 v součtu nastane
p(x - 1) + p(x - 2) = 2X-1 + 2X-2 < 2 ■ 2X-1 -1<2X.
Co přesně znamenají slova „v součtu"? To je, že všechny větve rekurzivního výpočtu dohromady na jedné úrovni sníží sledovaný parametr. Počet iterací výpočtu fibonacci(n) tak bude vždy nejen konečný, ale podle uvedené úvahy přímo striktně menší než p(n) = 2n.
Přesto, tento algoritmus je velmi pomalý a mnohem lepšího výpočetního času výpočtu Fibonacciho čísel dosáhneme třeba s alternativním algoritmem Příkladu 10.14. □
Dodatek: Jak konstruovat cykly permutace
Pro mírně složitější ilustraci výše uvedeného konceptu dokazování konečnosti se podíváme na snadný postup nalezení rozkladu permutace na cykly, u kterého však vůbec není na první pohled jasné, zda má skončit.
Algoritmus 11.6. Cykly permutace.
Pro danou permutací tt na n-prvkové neprázdné množínč A = {1,2,... ,n} vypíšeme její cykly (víz Oddíl 6.2) takto:
U 1 cyklů. Po první iteraci while cyklu zbude v restrikci permutace 7T na množinu U celkem l — 1 cyklů. Podle indukčního předpokladu pak tyto zbylé cykly budou správně vypsány a algoritmus skončí. □
Komentář: Vidíte, že v tomto důkaze indukcí je indukční krok zcela triviální a důležitý je zde především základ indukce?
Věta. Pokud 7r je permutace, tak vnitřní while cyklus vždy skončí a nalezne v 7T cyklus obsahující libovolný počáteční prvek x G U. Navíc všechny prvky nalezeného cyklu odebere z množiny U.
Důkaz: Zde přímo zopakujeme argument důkazu Věty 6.3: Vezmeme libovolný prvek x = x\ G U a iterujeme zobrazení Xi+i = tv(xí) pro i = 1, 2..., až dojde ke zopakování prvku Xk = Xj pro k > j > 1. (To musí nastat, neboť A je konečná.) Jelikož prvek Xj byl již odebrán z U, v kroku x = x^ dojde k ukončení našeho while cyklu. Nadto je 7r prostá, a proto nemůže nastat x\~ = x j = tt(xj_i) pro j > 1. Takto byl nalezen a odebrán z U cyklus (a1;..., a^-i) a důkaz je hotov. □
11.2 Přehled technik důkazu indukcí
Doposud v našem textu byla matematická indukce představována ve své přímočaré formě, kdy dokazované tvrzení obvykle přímo nabízelo celočíselný parametr, podle nějž bylo potřebné indukci vést. Indukční krok pak prostě zpracoval přechod „n = i —> n = i +1". To však u dokazování správnosti algoritmů typicky neplatí a našim cílem zde je ukázat možné techniky, jak správně indukci na dokazování algoritmů aplikovat. Uvidíme, jak si z nabízejících se parametrů správně vybrat a jak je případně kombinovat.
Technika fixace parametru
První technika důkazu prostě dopředu za některé parametry dosazuje (obecně zvolené) konstanty. Tato technika je vhodná pro případy, kdy je sice v algoritmu více parametrů, ale „zjevně" dochází ke změně jen jednoho (nebo části) z nich a chování algoritmu ke zbylým „neměnným" parametrům je dobře předvídatelné.
Příklad 11.7. Mějme následující algoritmus. Co je jeho výsledkem výpočtu?
Algoritmus .
input x, y; res ^— 0; while x>0 do
res ^— res + y; x ^— x-1;
done
output res;
100
Sledováním algoritmu zjistíme, že hodnota proměnné re s bude narůstajícím součtem y + • • • + y, dokud se x nesníží na nulu. Poté odhadneme:
Věta. Pro každé x,y G N Algoritmus 11.7 vypočítá hodnotu součinu res = x ■ y.
Jaký je vhodný postup k důkazu tohoto tvrzení indukcí? Je snadno vidět, že na hodnotě vstupu y vlastně nijak podstatně nezáleží (lze y fíxovat) a důležité je sledovat x. Tato úvaha nás dovede k následujícímu:
Důkaz: Budiž hy G N libovolné ale pro další úvahy pevné. Dokážeme, že pro každý vstup x G N je výsledkem výpočtu hodnota r0 + x ■ hy, kde hy byla hodnota vstupu y a r0 byla hodnota v pracovní proměnné res na začátku uvažovaného výpočtu (pro potřeby indukce, r0 = 0 na úplném začátku). Podle principu matematické indukce uplatněné na parametr x dostáváme snadno:
* Báze x = 0 znamená, že tělo cyklu ve výpočtu ani jednou neproběhne a výsledkem bude počáteční r$.
* Indukční krok. Nechť je tvrzení známo pro x = i a uvažujme nyní vstup x = i + 1 > 0. Prvním průchodem cyklem se uloží res 0 A n>0 then
res 0. Nyní je podmínka algoritmu splněna a vykonají se rekurentní volání
kombinační(m-1,n) + kombinační(m,n-l).
Rekurentní volání se vztahují k výběru podmnožin m — l+n = m + n — 1 = i-prvkové množiny, například M = {1,2,...,«}. Výsledkem tedy je, podle indukčního předpokladu pro součet i, počet (m — l)-prvkových plus m-prvkových podmnožin množiny M.
Kolik nyní je m-prvkových podmnožin (i + l)-prvkové množiny M' = M U {i + 1}? Pokud ze všech podmnožin odebereme prvek i + 1, dostaneme právě m-prvkové podmnožiny (z těch neobsahujících i + 1) plus (m — l)-prvkové podmnožiny (z těch původně obsahujících i + 1). A to je v součtu rovno kombinacni(m-l,n) + kombinacni (m,n-l), jak jsme měli dokázat. □
Zesílení dokazovaného tvrzení
Velmi častou situací při dokazování algoritmu je, že se zajímáme o hodnoty některých proměnných nebo „výstupy" některé funkce, ale ke správnému matematickému důkazu musíme „postihnout" i chování jiných funkcí a proměnných v algoritmu. Taková situace pak typicky vede na potřebu zesílení požadovaného tvrzení v matematické indukci.
Příklad 11.9. Zjistěte, kolik znaků 'z' v závislosti na celočíselné hodnotě n vstupního parametru n vypíše následující algoritmus.
Algoritmus 11.10.
st ^ "z" ;
foreach i«—1,2,3,...,n-l,n do
vytiskni řetězec st;
st ^— st . st ; (zřetězení dvou kopií st za sebou)
done
Zkusíme-li si výpočet simulovat pro n = 0,1,2,3,4..., postupně dostaneme počty 'z' jako 0,1,3,7,15.... Na základě toho již není obtížné „uhodnout", že počet 'z' bude (asi) obecně určen vztahem 2n — 1. Toto je však třeba dokázat!
Komentář: Jak záhy zjistíme, matematická indukce na naše tvrzení přímo „nezabírá", ale mnohem lépe se nám povede s následujícím přirozeným zesílením dokazovaného tvrzení:
Věta. Pro každé přirozené n Algoritmus 11.10 vypíše právě 2n — 1 znaků 'z' a proměnná st bude na konci výpočtu obsahovat řetězec 2n znaků ' z'.
102
Důkaz: Postupujeme indukcí podle n. ~Báze pro n = 0 je zřejmá, neprovede se ani jedna iterace cyklu a tudíž bude vytištěno 0 = 2° — 1 znaků 'z', což bylo třeba dokázat. Mimo to proměnná st iniciálně obsahuje 1=2° znak 'z'.
Nechť tedy tvrzení platí pro jakékoliv uq a položme n = uq + 1. Podle indukčního předpokladu po prvních uq iteracích bude vytištěno 2n° — 1 znaků ' z' a proměnná st bude obsahovat řetězec 2n° znaků 'z' .V poslední iteraci cyklu (pro i n=n0+l) vytiskneme dalších 2n° znaků 'z' (z proměnné st) a dále řetězec st „zdvojnásobíme". Proto po n iteracích bude vytištěno celkem 2n° — 1 + 2n° = 2n°+1 — 1 = 2n — 1 znaků 'z' a v st bude uloženo 2 • 2n° = 2no+1 = 2n znaků 'z'. □
11.3 Zajímavé algoritmy aritmetiky
Pro další ukázky důkazových technik pro algoritmy se podíváme na některé krátké algoritmy z oblasti aritmetiky. Například „zbytkové" umocňování na velmi vysoké exponenty je podkladem známé RSA šifry:
Algoritmus 11.11. Binární postup umocňování.
Pro daná čísla a, b vypočteme jejich celočíselnou mocninu (omezenou na zbytkové třídy modulo m kvůli prevenci přetečení rozsahu celých čísel v počítači), tj. ab mod m, následujícím postupem.
res <— 1;
while b > 0 do
if b mod 2 > 0 then res (res-a) mod m ; b |_b/2j ; a (a-a) mod m ;
done
output res;
K důkazu správnosti algoritmu použijeme indukci podle délky l binárního zápisu čísla b. Věta. Algoritmus 11.11 skončí a vždy správně vypočte hodnotu ab mod m.
Důkaz: Báze indukce je pro l = 1, kdy 6 = 0 nebo 6=1. Přitom pro 6 = 0 se cyklus vůbec nevykoná a výsledek je res = 1. Pro 6 = 1 se vykoná jen jedna iterace cyklu a výsledek je res = a mod m.
Nechť tvrzení platí pro £q > 1 a uvažme l = £q + 1. Pak zřejmě 6 > 2 a vykonají se alespoň dvě iterace cyklu. Po první iteraci budou hodnoty proměnných po řadě
ai = a2, 6i = [6/2J a res = n = (ab mod 2) mod m .
Tudíž délka binárního zápisu b\ bude jen £q a podle indukčního předpokladu zbylé iterace algoritmu skončí s výsledkem
res = ri ■ abl mod m = (ab mod 2 • a2^2-!) mod m = ab mod m.
□
Euklidův algoritmus
Již z dávných dob antiky pochází následující zajímavý a koneckonců velmi jednoduchý postup-algoritmus pro nalezení největšího společného dělitele dvou čísel.
103
Algoritmus 11.12. Euklidův pro největšího společného dělitele.
Pro zadaná přirozená čísla p, q počítá následovně: input p, q; while p>0 A q>0 do
if p>q then p p-q; else q q-p;
done
output p+q;
Věta. Pro každé p,q G N na vstupu algoritmus vrátí hodnotu největšího společného dělitele čísel pag, nebo 0 pro p = q = 0.
Důkaz opět povedeme indukcí podle součtu i = p + q vstupních hodnot. (Jak jsme psali, je to přirozená volba v situaci, kdy každý průchod cyklem algoritmu sníží jedno z p, q, avšak není jasné, které z nich.)
• Báze indukce pro i=p + q = 0]e zřejmá; cyklus algoritmu neproběhne a výsledek ihned bude 0.
• Ve skutečnosti je zase výhodné uvažovat rozšířenou bázi, která zahrnuje i případy, kdy jen jedno z p, q je nulové (Proč? Jedná se o všechny případy, kdy průchod cyklem neproběhne, neboli touto indukcí sledujeme počet průchodů cyklem.) Pak výsledek p + q bude roven tomu nenulovému z obou sčítanců, což jev tomto případě zároveň jejich největší společný dělitel.
• Indukční krok. Mějme nyní vstupní hodnoty p = /ip>0ag = /íg>0 - tehdy dojde k prvnímu průchodu tělem cyklu našeho algoritmu, přičemž hp + hq = i + 1. Předpokládejme hp > hq; poté po prvním průchodu tělem cyklu budou hodnoty p = hp — hq a q = hq, přičemž nyní p + q = hp < hp + hq — 1 = i.
Podle indukčního předpokladu (jelikož nyní p + q < i) tudíž výsledkem algoritmu pro vstupy p = hp — hq a q = hq bude největší společný dělitel NSD(hp — hq, hq). Symetricky pro hp < hq algoritmus vrátí NSD(hp, hq — hp). (Kde NSD() krátce označuje největšího společného dělitele.) Důkaz proto bude dokončen následujícím Lematem 11.13. □
Lema 11.13. Pro každá přirozená a, b platí NS D (a, b) = N SD(a — b,b) = NSD(a,b — a). Komentář: Všimněte si, že dělitelnost je dobře definována i na záporných celých číslech.
Důkaz: Ověříme, že c = NSD(a — b,b) je také největší společný dělitel čísel a a b (druhá část je pak symetrická).
• Jelikož číslo c dělí čísla a — b a b, dělí i jejich součet (a — b) + b = a. Potom c je společným dělitelem a a b.
• Naopak nechť d nějaký společný dělitel čísel a a b. Pak d dělí také rozdíl a — b. Tedy d je společný dělitel čísel a — b a b. Jelikož c je největší společný dělitel těchto dvou čísel, nutně d dělí c a závěr platí. □
Relativně rychlé odmocnění
Na závěr oddílu si ukážeme jeden netradiční krátký algoritmus a jeho analýzu a důkaz ponecháme zde otevřené. Dokážete popsat, na čem je algoritmus založen?
104
Algoritmus 11.14. Celočíselná odmocnina.
Pro dané přirozené číslo x vypočteme dolní celou část jeho odmocniny [^/x\:
p ^— x; res 0; while p > 0 do
while (res + p)2 < x do res res + p;
p <- Lp/2J ;
done
output res ;
Poznámka: Zamysleli jste se, jaký mají algoritmy v tomto oddíle vlastně význam? Vždyť stejné úlohy jistě sami vyřešíte každý jednou jednoduchou f oreach smyčkou. Podívejte se však (alespoň velmi zhruba) na počet kroků, které zde uvedené algoritmy potřebují vykonat k získání výsledku, a srovnejte si to s počty kroků oněch „jednoduchých" algoritmů.
Pro skutečně velká vstupní čísla zjistíte propastný rozdíl - s takovým „jednoduchým" algoritmem, třeba 'f oreach i 1, . . .b do res <— res-a mod m done', se pro obrovské hodnoty b výsledku nikdy nedočkáte, kdežto Algoritmus 11.11 stále poběží velmi rychle. (Spočítáte, jak rychle?) Obdobně je tomu u Algoritmu 11.14.
11.4 Dynamický algoritmus
Lekci zakončíme krátkou, ale velmi hezkou ukázkou tzv. dynamického algoritmu, který je znám pod jmény Floyd-Warshallův.
Komentář: Klíčovou myšlenkou dynamických algoritmů je rozklad problému na pod-problémy, jejichž řešení jsou postupně ukládána pro další možné použití. Metoda je obzvláště vhodná v případech, kdy rozložené podúlohy si jsou podobné a mohou se opakovat.
Metoda 11.15. Dynamický výpočet všech nejkratších cest
mezi vrcholy v grafu G na množině vrcholů V(G) = {vq,Vi, ... ,vn-i}.
• Na počátku nechť d[i,j] udává 1 (případně váhu-délku hrany {ví,Vj}), nebo oc pokud hrana mezi i, j není.
• Po kroku t > 0 nechť platí, že d[i,j] udává délku nejkratší cesty mezi vi}Vj, která užívá pouze vnitřní vrcholy z množiny {v0, v1}..., vt_{\ (prázdné ví = 0).
• Při přechodu z kroku t na následující krok t + 1 upravujeme vzdálenost pro každou dvojici vrcholů Ví,Vj - jsou vždy pouhé dvě možnosti:
* Buď je cesta délky d [i, j] z předchozího kroku t stále nejlepší (tj. nově povolený vrchol vt nám nepomůže),
* nebo cestu vylepšíme spojením přes nově povolený vrchol vt, čímž získáme menší vzdálenost d[i,t]+d[t,j] —>-d[i,j]. (Nakreslete si obrázek.)
• Po N krocích úprav je výpočet hotov. Výpočet nejkratších cest
Alternativně si zapíšeme postup této metody až překvapivě krátkým symbolickým algoritmem:
105
Algoritmus 11.16. Výpočet všech nejkratších cest; Floyd-Warshall
input ' Pole d [, ] délek hran (nebo oo) grafu G' ;
foreach t 0,1,..., N — 1 do
foreach i <- 0,1,..., N - 1, j <- 0,1,..., N - 1 do d[i,j] • B. Množiny A a, B jsou „stejné velké" právě když mezi nimi existuje bijekce. V případech nekonečných množin pak místo "velikosti" mluvíme formálně o jejich
Komentář: Uvedená definice kardinality množin „funguje" velmi dobře i pro nekonečné množiny:
* Například N a TL mají stejnou kardinalitu (jsou „stejně velké", tzv. spočetně nekonečné).
* Lze snadno ukázat, že i (Q je spočetně nekonečná, tj. existuje bijekce / : N —> (Q, stejně
107
jako bijekce h : N —> N2.
* Existují ale i nekonečné množiny, které jsou „striktně větší" než libovolná spočetná množina (příkladem je R ve Větě 12.2).
* Později dokážeme, že existuje nekonečná posloupnost nekonečných množin, z nichž každá je striktně větší než všechny předchozí.
Pro porovnávání velikostí množin někdy s výhodou využijeme následující přirozené, ale nelehké tvrzení (bez důkazu):
Věta 12.1. Pro libovolné dvě množiny A, B (i nekonečné) platí, že pokud existuje injekce A —>• B a zároveň i injekce B —>• A, pak existuje bijekce mezi A a B.
A
Cantorova diagonála, aneb kolik je reálných čísel
Prvním klíčovým poznatkem ukazujícím na neintuitivní chování nekonečných množin je následující důkaz, který dal historicky vzniknout metodě tzv. Cantorovy diagonály.
Věta 12.2. Neexistuje žádné surjektivní zobrazení g : N —y R.
Důsledek 12.3. Neexistuje žádné injektivní (tudíž ani bijektivní) zobrazení h : R —y N. Neformálně řečeno, reálnych čísel je striktně více než všech přirozených.
108
Důkaz (Věty 12.2 sporem): Nechť takové g existuje a pro zjednodušení se omezme jen na funkční hodnoty v intervalu (0,1). Podle hodnot zobrazení g si takto můžeme „uspořádat" dekadické zápisy všech reálných čísel v intervalu (0,1) po řádcích do tabulky:
9(0) 9(1) 9(2) 9(3) 2(4)
0. 0. 0. 0. 0.
5 4
4 2 7 5 7
9
3 2 5
Nyní sestrojíme číslo a E (0,1) následovně; jeho i-tá číslice za desetinnou čárkou bude 1, pokud v 2-tém řádku tabulky na diagonále není 1, jinak to bude 2. V našem příkladě a = 0.21211...
Kde se naše číslo a v tabulce nachází? (Nezapomeňme, g byla surjektivní, takže a někde musí být.) Konstrukce však ukazuje, že a se od každého čísla v tabulce liší na aspoň jednom desetinném místě, to je spor. (Až na drobný technický detail s rozvojem ...9.) □
12.2 „Naivní" množinové paradoxy
Analogickým způsobem k Větě 12.2 lze dokázat následovně zobecnění vyjadřující se o jakékoliv množině a jí přiřazené striktně větší.
Věta 12.4. Nechť M je libovolná množina. Pak existuje injektivní zobrazení f : M —> 2M, ale neexistuje žádné bijektivní zobrazení g : M —y 2M.
Důkaz: Dokážeme nejprve existenci /. Stačí ale položit f(x) = {x} pro každé x G M. Pak / : M —y 2M je zjevně injektivní.
Neexistenci g dokážeme sporem. Předpokládejme tedy naopak, že existuje bijekce g : M —>• 2M. Uvažme množinu K C M definovanou takto:
K = {xeM\x<£ g(x)}.
Jelikož g je bijektivní a K e 2M, musí existovat y e M takové, že g(y) = K. Nyní rozlišíme dvě možnosti:
- y G g (y). Tj. y G K. Pak ale y G7 g (y) z definice K, spor.
- y G7 g(y). To podle definice K znamená, že y e K, tj. y e g (y), spor. ^
Komentář: Dvě navazující poznámky. • Technika použitá v důkazech Vět 12.2 a 12.4 se nazývá Cantorova diagonální metoda, nebo také zkráceně diagonalizace.
Konstrukci množiny K lze znázornit pomocí následující tabulky:
b c d
g(o) i _y ...
9(b)
g(c) - X-\y • • •
g(d)
109
Symbol y/ resp. — říká, že prvek uvedený v záhlaví sloupce patří resp. nepatří do množiny uvedené v záhlaví řádku. Tedy např. d G g (b) a a 0 g (d). Množina K poté obsahuje ty diagonálni prvky označené —, tj. „převrací" význam diagonály.
• Z toho, že nekonečna mohou být „různě velká", lze lehce odvodit řadu dalších faktů. V jistém smyslu je např. množina všech problémů větší než množina všech algoritmů (obě množiny jsou nekonečné), a proto nutně existují problémy, které nejsou algoritmicky řešitelné.
Cantorův paradox
Naivní teorie množin, jak jsme si ji uvedli i v tomto předmětu, trpí mnoha neduhy a nepřesnostmi, které vyplynou na povrch především při „neopatrné manipulaci" s nekonečnými množinami. Abychom se těmto „neopatrnostem" vyhnuli bez přílišné formalizace, dva základní z těchto paradoxů si nyní ukážeme.
Příklad 12.5. Uvážíme-li nyní nekonečnou posloupnost množin
A1,A2,A3,A4,---
kde A\ = N a Ai+1 = 2Ai pro každé i G N, je vidět, že všechny množiny jsou nekonečné a každá je striktně větší než libovolná předchozí.
Kde však v tomto řazení kardinalit bude „množina všech množin"? Na tuto otázku, jak sami asi cítíte, nelze podat odpověď. Co to však znamená? □
* Takto se koncem 19. století objevil první Cantorův paradox nově vznikající teorie množin.
* Dnešní moderní vysvětlení paradoxu je jednoduché, prostě „množinu všech množin" nelze definovat, taková v matematice neexistuje.
Brzy se však ukázalo, že je ještě mnohem hůř... Russelův paradox
Fakt: Není pravda, že každý soubor prvků lze považovat za množinu.
* Nechť X = {M I M je množina taková, že M ^ M}. Platí X G X ?
- Ano. Tj. X G X. Pak ale X splňuje X g X.
- Ne. Pak X splňuje vlastnost X ^ X, tedy X je prvkem X, tj., X E X.
* Obě možné odpovědi vedou ke sporu. X tedy nelze prohlásit za množinu. Jak je ale něco takového vůbec možné?
Komentář: Vidíte u Russelova paradoxu podobnost přístupu s Cantorovou diagonalizací? Russelův paradox se objevil začátkem 20. století a jeho „jednoduchost" zasahující úplné základy matematiky (teorie množin) si vynutila hledání seriózního rozřešení a rozvoj formální matematické logiky.
Pro ilustraci tohoto paradoxu, slyšeli jste už, že „v malém městečku žije holič, který holí právě ty muže městečka, kteří se sami neholí"? Zmíněné paradoxy naivní teorie množin zatím v tomto kurzu nerozřešíme, ale zapamatujeme si, že většina matematických a informatických disciplín vystačí s „intuitivně bezpečnými" množinami.
110
12.3 Algoritmická neřešitelnost problému zastavení
Výše vysvětlené myšlenky diagonalizace a principů základních paradoxů naivní teorie množin sice vypadají „velmi matematicky". Přesto je však téměř beze změny lze aplikovat i na bytostně informatickou otázku, zda lze algoritmicky poznat, pro které vstupy se daný algoritmus vůbec zastaví. Negativní odpověď na tuto otázku je jedním z fundamentálních výsledků informatiky a přitom má překvapivě krátký a čistý důkaz diagonalizací.
Fakt: Uvědomme si (velmi neformálně) několik základních myšlenek.
* Program v každém programovacím jazyce je konečná posloupnost složená z konečně mnoha symbolů (písmena, číslice, mezery, speciální znaky, apod.) Nechť E je množina všech těchto symbolů. Množina všech programů je tedy jistě podmnožinou množiny UieN^1' která je spočetně nekonečná. Existuje tedy bijekce / mezi množinou N a množinou všech programů. Pro každé j G N označme symbolem Pj program f(j). Pro každý program P tedy existuje i G N takové, že P = Pí.
* Každý možný vstup každého možného programu lze zapsat jako konečnou posloupnost symbolů z konečné mnočiny T. Množina všech možných vstupů je tedy spočetně nekonečná a existuje bijekce g mezi množinou N a množinou všech vstupů. Pro každé j G N označme symbolem Vj vstup g(j).
* Předpokládejme, že existuje program H alt, který pro dané i, j G N zastaví s výstupem ano/ne podle toho, zda Pí pro vstup Vj zastaví, nebo ne.
* Tento předpoklad dále dovedeme ke sporu dokazujícímu, že problém zastavení nemá algoritmické řešení.
Věta 12.6. Neexistuje program Halt, který by pro vstup (Pí, Vj) správně rozhodl, zda se program Pí zastaví na vstupu Vj.
Důkaz: Sporem uvažme program Diag s následujícím kódem: input k;
if iJa/£(k,k) =ano then while true do ; done
(Program Diag(k) má na rozdíl od Halt jen jeden vstup k, což bude důležité.) Fungování programu Diag lze znázornit za pomocí následující tabulky:
Symbol y/ resp. — říká, že program uvedený v záhlaví sloupce zastaví resp. nezastaví pro vstup uvedený v záhlaví řádku. Program Diag „zneguje" diagonálu této tabulky.
Podle našeho předpokladu (Diag je program a posloupnost Pj zahrnuje všechny programy) existuje j G N takové, že Diag = Pj. Zastaví Diag pro vstup Vj?
Po Pi P2 P3
V0
v1 v2 v3
111
- Ano. Podle kódu Díag pak ale tento program vstoupí do nekonečné smyčky, tedy nezastaví.
- Ne. Podle kódu Díag pak ale if test neuspěje, a tento program tedy zastaví. Předpoklad existence programu Halt tedy vede ke sporu. □
Komentář: Otázkami algoritmické (ne)řešitelnosti problémů se zabývá teorie vyčíslitelnosti. Metoda diagonalizace se také často využívá v teorii složitosti k důkazu toho, že dané dvě složitostní třídy jsou různé.
Rozšiřující studium
Látka této lekce zabrousila až do teoretických hlubin matematické logiky a teorie množin. Další studium v těchto oblastech se dá očekávat hlavně u studentů speciňcky zaměřených teoretickým směrem (a mířících spíše do akademické než aplikační sféry), zajímajících se o matematiku samotnou nebo o teorii vyčíslitelnosti. Proto také uvedené pokročilé poznatky Lekce 12 nebudou vyžadovány u zkoušky tohoto předmětu.
112
Závěrem
Gratulujeme všem, kteří se naším nelehkým učebním textem „prokousali" až sem, a přejeme mnoho úspěchů v dalším studiu informatiky.
Konečně znovu připomínáme, že nedílnou součástí našeho studijního textu je Interaktivní osnova předmětu IB000 v IS MU a v ní přiložené online odpovědníky určené k procvičování přednesené látky.
http://is.muni.cz/el/1433/podzim2014/IB000/index.qwarp
113