Kokeessa saa olla mukana A4:n kokoinen kaksipuoleinen kynällä tehty, itse kirjoitettu lunttilappu

Samankaltaiset tiedostot
Koe ma 1.3 klo salissa A111, koeaika kuten tavallista 2h 30min

TKT20001 Tietorakenteet ja algoritmit Erilliskoe , malliratkaisut (Jyrki Kivinen)

Algoritmi on periaatteellisella tasolla seuraava:

58131 Tietorakenteet ja algoritmit (kevät 2013) Kurssikoe 2, , vastauksia

58131 Tietorakenteet ja algoritmit (syksy 2015) Toinen välikoe, malliratkaisut

2. Seuraavassa kuvassa on verkon solmujen topologinen järjestys: x t v q z u s y w r. Kuva 1: Tehtävän 2 solmut järjestettynä topologisesti.

58131 Tietorakenteet ja algoritmit Uusinta- ja erilliskoe malliratkaisut ja arvosteluperusteet

Luku 7. Verkkoalgoritmit. 7.1 Määritelmiä

Koe ma 28.2 klo salissa A111, koeaika kuten tavallista 2h 30min

58131 Tietorakenteet Erilliskoe , ratkaisuja (Jyrki Kivinen)

Algoritmit 1. Luento 8 Ke Timo Männikkö

Algoritmit 1. Luento 3 Ti Timo Männikkö

58131 Tietorakenteet ja algoritmit (kevät 2016) Ensimmäinen välikoe, malliratkaisut

Hakupuut. tässä luvussa tarkastelemme puita tiedon tallennusrakenteina

Algoritmit 2. Luento 14 Ke Timo Männikkö

Algoritmit 1. Luento 9 Ti Timo Männikkö

Algoritmit 2. Luento 3 Ti Timo Männikkö

Algoritmit 2. Luento 3 Ti Timo Männikkö

Verkon virittävät puut

Eräs keskeinen algoritmien suunnittelutekniikka on. Palauta ongelma johonkin tunnettuun verkko-ongelmaan.

13 Lyhimmät painotetut polut

Algoritmit 2. Luento 2 Ke Timo Männikkö

Oikeasta tosi-epätosi -väittämästä saa pisteen, ja hyvästä perustelusta toisen.

Algoritmit 2. Luento 2 To Timo Männikkö

Lyhin kahden solmun välinen polku

58131 Tietorakenteet ja algoritmit Uusinta- ja erilliskoe ratkaisuja (Jyrki Kivinen)

Algoritmit 1. Luento 1 Ti Timo Männikkö

58131 Tietorakenteet (kevät 2009) Harjoitus 9, ratkaisuja (Antti Laaksonen)

58131 Tietorakenteet ja algoritmit (kevät 2014) Uusinta- ja erilliskoe, , vastauksia

Algoritmit 1. Luento 14 Ke Timo Männikkö

ALGORITMIT 1 DEMOVASTAUKSET KEVÄT 2012

Tietorakenteet, laskuharjoitus 10, ratkaisuja. 1. (a) Seuraava algoritmi tutkii, onko jokin luku taulukossa monta kertaa:

Pienin virittävä puu (minimum spanning tree)

Esimerkkejä polynomisista ja ei-polynomisista ongelmista

5. Keko. Tietorakenne keko eli kasa (heap) on tehokas toteutus abstraktille tietotyypille prioriteettijono, jonka operaatiot ovat seuraavat:

Algoritmit 1. Luento 2 Ke Timo Männikkö

Algoritmit 2. Luento 4 Ke Timo Männikkö

A TIETORAKENTEET JA ALGORITMIT

Algoritmit 2. Luento 4 To Timo Männikkö

811312A Tietorakenteet ja algoritmit Kertausta jälkiosasta

Algoritmit 2. Luento 7 Ti Timo Männikkö

Tietorakenteet ja algoritmit. Kertaus. Ari Korhonen

3. Hakupuut. B-puu on hakupuun laji, joka sopii mm. tietokantasovelluksiin, joissa rakenne on talletettu kiintolevylle eikä keskusmuistiin.

On annettu jono lukuja tai muita alkioita, joiden välille on määritelty suuruusjärjestys. Tehtävänä on saattaa alkiot suuruusjärjestykseen.

lähtokohta: kahden O(h) korkuisen keon yhdistäminen uudella juurella vie O(h) operaatiota vrt. RemoveMinElem() keossa

Algoritmit 2. Luento 13 Ti Timo Männikkö

TIE Tietorakenteet ja algoritmit 261

811312A Tietorakenteet ja algoritmit III Lajittelualgoritmeista

Algoritmit 1. Luento 13 Ma Timo Männikkö

Algoritmit 1. Luento 12 Ti Timo Männikkö

811312A Tietorakenteet ja algoritmit V Verkkojen algoritmeja Osa1 : Leveys- ja syvyyshaku

58131 Tietorakenteet ja algoritmit (syksy 2015)

AVL-puut. eräs tapa tasapainottaa binäärihakupuu siten, että korkeus on O(log n) kun puussa on n avainta

4 Tehokkuus ja algoritmien suunnittelu

Johdatus graafiteoriaan

58131 Tietorakenteet ja algoritmit (kevät 2013) Kurssikoe 1, , vastauksia

Tietorakenteet ja algoritmit - syksy

Tietorakenteet ja algoritmit Johdanto Lauri Malmi / Ari Korhonen

V. V. Vazirani: Approximation Algorithms, luvut 3-4 Matti Kääriäinen

Algoritmit 1. Luento 13 Ti Timo Männikkö

(a) L on listan tunnussolmu, joten se ei voi olla null. Algoritmi lisäämiselle loppuun:

Tietorakenteet ja algoritmit syksy Laskuharjoitus 1

Algoritmit 2. Luento 11 Ti Timo Männikkö

811312A Tietorakenteet ja algoritmit Kertausta jälkiosasta

2. Johdanto tietorakenteisiin

1 Puu, Keko ja Prioriteettijono

Algoritmit 1. Luento 12 Ke Timo Männikkö

Alaraja vertailuihin perustuvalle järjestämiselle

Tietorakenteet, laskuharjoitus 3, ratkaisuja

Algoritmit 2. Luento 14 To Timo Männikkö

A ja B pelaavat sarjan pelejä. Sarjan voittaja on se, joka ensin voittaa n peliä.

5. Hajautus. Tarkastellaan edelleen sivulla 161 esitellyn joukkotietotyypin toteuttamista

4. Joukkojen käsittely

Olkoon seuraavaksi G 2 sellainen tasan n solmua sisältävä suunnattu verkko,

Tietorakenteet, laskuharjoitus 7, ratkaisuja

Algoritmit 1. Luento 11 Ti Timo Männikkö

Olkoon S(n) kutsun merge-sort(a, p, q) tilavaativuus kun p q + 1 = n. Oletetaan merge toteutetuksi vakiotyötilassa (ei-triviaalia mutta mahdollista).

Algoritmit 2. Luento 8 To Timo Männikkö

811312A Tietorakenteet ja algoritmit V Verkkojen algoritmeja Osa 2 : Kruskalin ja Dijkstran algoritmit

1. (a) Seuraava algoritmi tutkii, onko jokin luku taulukossa monta kertaa:

8. Yhteenvetoa. abstrakti tietotyyppi: mitä datalle halutaan tehdä tietorakenne: miten se tehdään (talletusrakenne, operaatioden toteutus)

Kurssikoe on maanantaina Muista ilmoittautua kokeeseen viimeistään 10 päivää ennen koetta! Ilmoittautumisohjeet löytyvät kurssin kotisivuilla.

Induktiotodistus: Tapaus n = 0 selvä; ol. väite pätee kun n < m.

Algoritmit 2. Luento 5 Ti Timo Männikkö

Hajautus. operaatiot insert ja search pyritään tekemään erittäin nopeiksi

Tietorakenteet (syksy 2013)

Datatähti 2019 loppu

Tehtävän V.1 ratkaisuehdotus Tietorakenteet, syksy 2003

58131 Tietorakenteet (kevät 2009) Harjoitus 11, ratkaisuja (Topi Musto)

Tiraka, yhteenveto tenttiinlukua varten

Algoritmit 2. Luento 5 Ti Timo Männikkö

10. Painotetut graafit

Algoritmit 1. Luento 10 Ke Timo Männikkö

Tietorakenteet ja algoritmit

Luku 8. Aluekyselyt. 8.1 Summataulukko

Olemme käsitelleet yksinkertaistettua tilannetta, jossa puun solmuihin ei ole talletettu muuta kuin avaimen arvo

Miten käydä läpi puun alkiot (traversal)?

Algoritmit 2. Luento 6 Ke Timo Männikkö

Tietorakenteet ja algoritmit. Verkot. Ari Korhonen

Tarkennamme geneeristä painamiskorotusalgoritmia

Transkriptio:

Toinen kurssikoe Koe to 5.5 klo 9-12 salissa A111, koeaika normaalista poiketen 2h 45 min Kokeessa saa olla mukana A4:n kokoinen kaksipuoleinen kynällä tehty, itse kirjoitettu lunttilappu lunttilapun teossa ei siis saa käyttää kopiokonetta eikä tietokonetta kannattaa huomata, että lunttilapun takia kokeen kysymyksissä pääpaino on kurssilla käsiteltävien asioiden soveltaminen koekysymykset ovat tyyliltään esim. seuraavanlaisia minkälainen on tietorakenne x selitä miten algoritmi x toimii kehitä algoritmi ongelmaan x määritä algoritmin x aikavaativuus todista, että... eli koetehtävät ovat pääosin tyyliltään laskaritehtävien kaltaisia 1

Tärkeää ja vähemmäntärkeää koealue monisteen sivut 277-525 ja laskuharjoitukset 8-12 Toisen periodin neljä ydinteemaa hajautus, keko, järjestäminen ja verkot Kokeessa on kysymyksiä kaikista ydinteemoista Edellisten lisäksi aika- ja tilavaativuusanalyysi on edelleen osattava Toisen kurssikokeen kannalta vähemmän tärkeää Java-spesifiset asiat Alaraja vertailuihin perustuvalle järjestämiselle (s 375-379) järjestäminen lineaarisessa ajassa (s 379-386) Union-find-tietorakenteen yksityiskohdat (s. 518-523) B+-puista tai A*-algoritmista ei tule kysymyksiä toiseen kurssikokeeseen seuraavilla kalvoilla on listattu tärkeimpä teemoja eri aihepiireistä teknistä asiaa kalvoilla ei juuri ole, eli ne toimivat vain lukuohjeena ja varsinainen asia löytyy luentokalvoista 2

Aika- ja tilavaativuusanalyysi Aikavaativuus: algoritmin käyttämä laskenta-"aika" syötteen koon funktiona Tilavativuus: algoritmin käyttämän aputilan määrä syötteen koon funktiona Tarkastellaan lähes koko kurssin ajan pahimman tapauksen vaativuutta, miten paljon aikaa/tilaa algoritmin suorituksessa kuluu enimmillään poikkeuksena hajautus ja pikajärjestäminen, joissa kiinnostavaa on keskimääräisen tapauksen vaativuus Kiinnostavaa on mihin vaativuusluokkaan algoritmi kuuluu O(1), O(logn), O(n), O(n 2 ), O(2 n ),... usein analyysissä riittävät seuraavan kalvon nyrkkisäännöt joidenkin verkkoalgoritmien aikavaativuusanalyysissä nyrkkisääntöjen suoraviivainen soveltaminen ei riitä rekursiivisten algoritmien tilavaativuuden analysoinnissa on otettava huomioon rekursion syvyys (ks. sivu 59) koealueeseen kuuluu paljon rekursiivisia algoritmeja, joten muista kerrata tämä asia! 3

Algoritmien aikavaativuusanalyysin nyrkkisäännöt 1. yksinkertaisten käskyjen aikavaativuus on vakio eli O(1) 2. peräkkäin suoritettavien käskyjen aikavaativuus on sama kuin käskyistä eniten aikaavievän aikavaativuus 3. ehtolauseen aikavaativuus on O(ehdon testausaika + suoritetun vaihtoehdon aikavaativuus) 4. aliohjelman suorituksen aikavaativuus on O(parametrien evaluointiaika + parametrien sijoitusaika + aliohjelman käskyjen suoritusaika) 5. looppeja sisältävän algoritmin aikavaativuuden arvioiminen: arvioi sisimmän loopin runko-osan aikavaativuus: O(runko) arvioi kuinka monta kertaa sisin looppi yhteensä suoritetaan: lkm aikavaativuus on O(lkm runko) 6. rekursiota käyttävien algoritmien aikavaativuuden arvioiminen: arvioi pelkän rekursiivisen aliohjelman runko-osan aikavaativuus: O(runko) arvioi kuinka monta kertaa rekursiokutsu yhteensä suoritetaan: lkm aikavaativuus on O(lkm runko) 4

Hajautus Käyttötarkoitus: abstrakti tietotyyppi joukko insert, delete ja search keskimäärin nopeita eli O(1) pahimmassa tapauksessa kuitenkin O(n) muut joukon operaatiot O(n) oikea täyttösuhde n/m, missä n talletettujen alkioiden määrä ja m hajautusrakenteen koko, tärkeä! yhteentörmäys ja sen selvitysstrategiat ketjutus avoin hajautus hajautusfunktion valinta oleellinen tehokkuuden kannalta jakojäännösmenetelmä kertolaskumenetelmä (kolmas, vähemmän tärkeä: universaalihajautus) 5

millä perusteilla hajautusfunktion valinta tapahtuu? saadaanko hajautustaulun koko valita vapaasti jos hajautettavat avaimet ovat muun tyyppisiä kuin lukuja, esim. merkkijonoja, miten tällöin toimitaan? ensin muunnos avaimen tyypistä etumerkittömäksi kokonaisluvuksi ja sitten hajautus tai suoraan kuvaus esim. merkkijonolta hajautusalueelle avoimen hajautuksen erilaiset kokeilustrategiat: lineaarinen kokeilu, neliöinen kokeilu, kaksoishajautus entä jos hajautusalue tulee liian täyteen? uudelleenhajautus, vie aikaa suoritettaessa mutta kannattaa pidemmän päälle missä tilanteessa hajautusta kannattaa käyttää ja missä ei? mikä on vaihtoehto? 6

Keko kaksi versiota: minimikeko ja maksimikeko muutama tehokkaasti eli ajassa O(logn) toimiva operaatio heap-insert minimikeossa heap-del-min, heap-dec-key maksimikeossa heap-del-max, heap-inc-key kekoehdon korjaava apuoperaatio heapify Käyttötarkoitus: prioriteettijono (minimikeko) kekojärjestäminen (maksimikeko) 7

keko ajatellaan binääripuuna kekoehdot vanhempi suurempi kuin lapset (maksimikeossa) "mahdollisimman" täysi, lehdet mahdoillisimman vasemmalla katso tarkemmin sivulta 309 keko on melkein täydellinen binääripuu (s. 145 ja 147) tästä seuraa, että keko on tasapainoinen binääripuu ja sen korkeus solmumäärän n suhteen on vain noin logn operaatiot kulkevat pahimmassa tapauksessa keon juuresta lehteen tai lehdestä juureen operaatioiden aikavaativuus O(logn) ks. esimerkiksi heapify s. 324 tai heap-insert s. 329 vaikka keko ajatellaan puuna, se talletetaan taulukkoon ei tarvita viitteitä: vie vähän muistia ja liikkuminen keossa nopeaa 8

Järjestäminen Kiinnostavimpia tietysti ajassa O(nlogn) toimivat, eli kekojärjestäminen lomitusjärjestäminen pikajärjestäminen Kekojärjestäminen tehdään taulukosta maksimikeko, toimenpide vaatii n/2 heapify-operaatiota viedään alkiot taulukkoon paikalleen kutsumalla n kertaa heap-del-max koska heapifyn ja heap-del-max:n aikavaativuus on O(logn), on aikavaativuus kokonaisuudessaan O(nlogn) algoritmi ei vaadi kuin vakiomäärän aputilaa Lomitus- ja pikajärjestäminen perustuvat hajoita-ja-hallitse (engl. divide-and-conquer) -tekniikkaan: hajoitetaan ongelma pienempiin osaongelmiin hallitaan, eli ratkaistaan osaongelmat rekursiivisesti yhdistetään osaratkaisut siten että saadaan ratkaisu koko ongelmalle 9

molemmat toteuttavat periaatetta hieman eri tavalla lomitusjärjestämisessä hajoittaminen tarkottaa taulukon puolittamista, yhdistämisessä taas tehdään lomitusoperaatio merge merge-sort(a,vasen,oikea) 1 if vasen<oikea 2 keski = (vasen+oikea)/2 3 merge-sort(a,vasen,keski) 4 merge-sort(a,keski+1,oikea) 5 merge(a,vasen,keski,oikea) pikajärjestämisessä hajoittamisessa siirrellään alkiota siten, että pienet menevät vasemmalle ja isot oikealle puolelle, yhdistämisvaihetta ei tarvita! quick-sort(a,vasen,oikea) 1 if vasen<oikea 2 jako = partition(a,vasen,oikea) 3 quick-sort(a,vasen,jako) 4 quick-sort(a,jako+1,oikea) hallintavaihe tarkoittaa (useimmiten) rekursiivista kutsua, jolla ratkaistaan alkuperäisen ongelman osaongelma 10

Lomitusjärjestäminen hajoittaminen vaan etsii taulukonosan puolen välin, eli operaatio on kevyt O(1) yhdistämisvaihe eli merge käy molemmat puolikkaat läpi ja vie aikaa O(k) jos yhdistettävien puolikkaiden yhteenlaskettu koko on k yhdistämisvaihe tarvitsee aputaulukon eli vie tilaa O(k) algoritmin aikavaativuuden selvittämisessä kannattaa miettiä rekursiopuuta (s. 354-357) lasketaan rekursiivisen funktion rungon vievä aika (joka on käytännössä sama kuin mergeen menevä aika) yhteen tasoittain jokaisen tason merget vievät yhteenlaskien aikaa O(n) huomioidaan että tasojen lukumäärä on logn+1 jos taulukon koko on n (s. 356) tästä päädytään aikavaativuuteen O(nlogn) nyrkkisäännön 6 suoraviivainen soveltaminen ei tässä riitä sillä eri rekursiokutsujen viemä aikamäärä ei ole sama tilavaativuus: 11

rekursion takia O(logn) merge-operaation O(n) kuitenkin dominoi tilavaativuutta

Pikajärjestäminen hajoittaminen eli partition vie jakoalkiota pienemmät taulukon vasemmalle ja suuremmat oikealle puolelle (s 361-363) jakoalkio ja sen kanssa samansuuruiset alkiot tulevat yleensä taulukon oikealle puolelle partition-operaatio käy koko taulukonosan läpi eli sen aikavaativuus on O(k) jos hajoitettavassa taulukonosassa k alkiota yhdistämisvaihetta ei siis tarvita koska rekursiivisten kutsujen jälkeen sekä vasen että oikea puoli taulukosta järjestyksessä ja pienet alkiot ovat kaikki vasemmalla ja isot oikealla puolella jakoalkion valinta ratkaisee kuinka tasan jako menee jaon tasaisuuden takia paras valinta olisi jaettavan taulukonosan alkioiden mediaani mediaanin valinta ei kannata sillä se hidastaisi algoritmia liikaa hyvä valinta "kolmen mediaani", ks s. 374 12

aikavaativuus: pahin tapaus: jos partition jakaa alkiota lähes aina huonosti (toiselle puolelle vain yksi tai muutama alkio), toimii algoritmi ajassa O(n 2 ) s. 367 keskimäärin algoritmi toimii ajassa O(nlogn), keskimääräisen tapauksen aikavaativuusanalyysi ei kuulu kurssille algoritmin pahin tapaus on erittäin harvinainen tilavaativuuden ratkaisee rekursion syvyys keskimäärin O(log n) pahimmassa tapauksessa algoritmin perusversiossa O(n) käytännössä pikajärjestämistä kannattaa viritellä, s. 374 Järjestäminen algoritmien esiprosessointivaiheena järjestä ensin käsiteltävä data niin algoritmin jatkotoimet helpottuvat, esim. lh10 tehtävät 1 ja 2 Kruskalin algoritmi... 13

Verkot solmujen joukko V, kaarien joukko E kaarien lukumääräästä käytetään merkintää V ja solmujen lukumäärästä E Käsitteet: suuntaamaton verkko, suunnattu verkko kaaripainot vai ei vierussolmu polku, sykli saavutettavuus syklitön verkko vahvasti yhtenäinen verkko yhtenäinen verkko esitystavat vieruslista vierusmatriisi 14

Verkon läpikäynti idea siis käydä kaikissa verkon solmuissa tai kaikissa lähtösolmusta s saavutettavissa olevissa solmuissa verkoilla ei kaaripainoja tai kaaripainoja ei huomioida! algoritmit toimivat sekä suunnatuilla että suuntaamattomilla verkoilla leveyssuuntainen läpikäynti (breath first search eli bfs) edetään taso kerrallaan, ensin vieraillaan lähtösolmun vierussolmuissa, sitten vierussolmujen vierussolmuissa,... merkataan solmut vierailluiksi (musta väri) jotta algoritmi ei jää looppiin selvittää lyhimmät polut lähtösolmusta muihin solmuihin polun pituudella tarkoitetaan kaarien määrää, kaaripainoja ei siis huomioida algoritmissa! 15

syvyyssuuntainen läpikäynti (depth first search eli dfs) edetään polku kerrallaan merkataan solmut ensin löydetyksi (harmaa) ja lopulta käsitellyksi (musta) harmaat solmut ovat niitä joista saavutettavien solmujen tutkiminen on vielä kesken syvyyssuuntaisen läpikäynnin sovellukset: verkon syklittömyyden tarkastus: verkossa sykli jos ja vain jos etsinnän aikana kohdataan harmaa solmu syklittömän verkon solmut voidaan järjestää dfs:n avulla topologisesti: kun solmu muuttuu mustaksi, laitetaan se pinoon vahvasti yhtenäisten komponenttien selvittäminen leveys- ja syvyyssuuntaista algoritmia voidaan siis soveltaa suuntaamattomiin ja suunnattuihin verkkoihin topologinen järjestäminen ja vahvasti yhtenäisten komponenttien selvittäminen mielekästä vain suunnatuille verkoille 16

Verkkoalgoritmien aikavaativuus algoritmien aikavaativuus riippuu yleensä sekä solmujen lukumäärästä V että kaarien lukumäärästä E tarkastellaan syvyyssuuntaista läpikäyntiä DFS(G,s) 1 for jokaiselle solmulle u V 2 color[u] = white 3 DFS-visit(G,s) DFS-visit(G,u) 4 color[u] = gray 5 for jokaiselle solmulle v vierus[u] 6 if color[v]==white // solmua v ei vielä löydetty 7 DFS-visit(G,v) 8 color[u] = black riveillä 1-2 suoritetaan for-looppi jokaiselle solmulle, eli V kertaa, forin runko-osan vaativuus O(1), eli nyrkkisäännön 5 (ks. kalvo 4) perusteella rivien 1-2 aikavaativuus on O( V ) rivin 3 aikavaativuus on nyrkkisäännön 4 perusteella sama kuin rekursiivisen kutsun DFS-visit aikavaativuus 17

mikä on rekursiivisen kutsun DFS-visit aikavaativuus? nyrkkisääntö 6 neuvoo laskemaan rekursiivisten kutsujen lukumäärän ja arvioimaan runko-osan suorittamiseen menevän ajan rekursiivinen kutsu suoritetaan enimmillään kerran jokaiselle solmulle, eli kutsuja on V kappaletta kutsu nimittäin suoritetaan vain jos solmu on valkoinen ja jokainen valkoinen solmu muuttaa heti kutsun tapahduttua värinsä entä rekursiivisen metodin runko-osan vaativuus? runko-osassa on kaksi vakioaikaista käskyä (rivit 4 ja 8) sekä for-looppi, jossa tutkitaan käsiteltävän solmun u vierussolmut for-loopin suorituskerrat vaihtelevat jokaisen rekursiivisen kutsun osalta yhteenlaskettuna kaikkien rekursiivisten DFS-visit-kutsujen aikana käydään läpi jokaisen solmun jokainen vierussolmu toisin sanoen for:eissa käydään kaikki rekursiiviset kutsut huomioiden läpi kaikki verkon kaaret jos verkko on suuntaamaton, käydään jokainen kaari läpi molempiin suuntiin 18

kaikkien rekursiivisten DFS-visit-kutsujen runko-osien yhteenlaskettu aikavaativuus on siis O( V + E ) V tulee rekursiivisten kutsujen lukumäärästä E taas tulee kaikkien rekursiivisten kutsujen for-lauseiden runkojen yhteenlasketusta suoritusmäärästä nyrkkisääntöä 6 ei voitu soveltaa suoraan, sillä rekursiivisten kutsujen vaativuus vaihtelee kutsuittain algoritmin rivit 1-2 siis vievät aikaa O( V ) ja rivi 3, joka sisältää rekursiivisen kutsun vie aikaa O( V + E ) nyrkkisäännön 2 perusteella tämä on yhteensä O( V + E ) 19

jos verkon jokaisen solmun välillä on kaari, niin E = V 2 tälläisessä tilanteessa leveyssuuntaisen läpikäynnin aikavaativuus voidaan ilmaista pelkkien solmujen lukumäärän suhteen ja se on O( V + E ) = O( V + V 2 ) = O( V 2 ) tilanne on sama, jos verkossa on esim. jokaisesta solmusta kaari kolmasosaan muita solmuja: nyt E = 1 3 V 2 ja läpikäynnin aikavaativuus solmujen määrän suhteen on O( V + E ) = O( V + 1 3 V 2 ) = O( V 2 ) jos taas kaaria on vähän, esim. korkeintaan 3 kaarta jokaisesta solmusta, on E 3 V eli E = O( V ) läpikäynnin aikavaativuus voidaan ilmaista pelkkien solmujen määrän suhteen ja se on O( V + E ) = O( V +3 V ) = O( V ) usein kaarten ja solmujen lukumäärän suhdetta ei tiedetä ja sen takia aikavaativuus ilmaistaan molemmista riippuvalla ilmaisulla O( V + E ) lähes kaikkien kurssin verkkoalgoritmien aikavaativuusanalyysi etenee samaan tyyliin, eli rekursion tai loopin analysoinnissa joudutaan huomioimaan kaikkien kaarten läpikäynti 20

Lyhimmät polut Dijkstran algoritmi algoritmi tarkoitettu kaaripainollisille verkoille laskee lyhimmän etäisyyden ja selvittää lyhimmän polun lähtösolmusta s jokaiseen muuhun solmuun polun pituudella tarkoitetaan kaaripainojen summaa ei toimi jos kaaripainot negatiivisia toimii sekä suunnatuilla että suuntaamattomilla verkoilla nodattaa ahnetta periaatetta: etenee aina lähimpään solmuun toteutuksesta saadaan tehokas käyttämällä minimikekoa aikavaativuusanalyyssä tärkeä muistaa, että keko-operaatioiden vaativuus on O(log V ) jos keossa pahimmillaan V solmua 21

Floyd-Warshallin algoritmi algoritmi tarkoitettu kaaripainollisille verkoille laskee lyhimmän etäisyyden ja selvittää lyhimmän polun kaikkien solmujen välillä verkossa saa olla myös negatiivisia kaaripainoja verkossa ei kuitenkaan saa olla negatiivisia syklejä toimii sekä suunnatuilla että suuntaamattomilla verkoilla toimintaperiaate eroaa radikaalisti muista verkkoalgoritmeista kolme sisäkkäistä for-lausetta solmujoukon yli, eli aikavaativuus ilmiselvästi O( V 3 ) käyttää aputilaa O( V 2 ) 22

Minimaaliset virittävät puut Mitä tarkoitetaan virittävällä puulla? Entä minimaalisella virittävällä puulla? Käsite minimaalinen virittävä puu on mielekäs vain yhtenäisille suuntaamattomille kaaripainollisille verkoille Primin algoritmi aloitetaan jostain solmusta lisätään virittävään puuhun solmu kerrallaan toimien niin, että aina lähimpänä puun ulkopuolella oleva solmu ja sen puuhun yhdistävä kaari lisätään seuraavaksi virittävään puuhun aputietorakenteena minimikeko Kruskalin algoritmi järjestetään kaaret painonmukaiseen järjestykseen, kevein ensin otetaan kaaria mukaan järjestyksessä siten, että kaari hylätään jos se muodostaa syklin (eli päätepisteet eivät ole eri palassa) aputietorakenteena union-find (joka ei kovin tärkeä kokeen kannalta) aikavaativuus molemmissa suunilleen sama, eli Prim O( E log V ) ja Kruskal O( E log E ) 23

Verkkoalgoritmit ongelmanratkaisussa Monet verkkoalgoritmeista ovat aika kompakteja ja niiden toimintaperiaate on suhteellisen helppo ymmärtää aina ei ole kuitenkaan täysin selvää, että algoritmi toimii kuten halutaan ja tarvitaan matemaattista analyysiä algoritmien oikeellisuuden osoittamiseen toinen haastava asia on se, kuinka verkkoalgoritmeja sovelletaan ongelmanratkaisuun välillä soveltaminen on melko suoraviivaista joskus ongelman muuttaminen verkko-ongelmaksi vaatii jonkin verran miettimistä ja välillä vaaditaan epätriviaalia matematiikkaa 24