1.1 Tavallinen binäärihakupuu



Samankaltaiset tiedostot
14 Tasapainotetut puurakenteet

9.3 Algoritmin valinta

Hakupuut. tässä luvussa tarkastelemme puita tiedon tallennusrakenteina

Pinot, jonot, yleisemmin sekvenssit: kokoelma peräkkäisiä alkioita (lineaarinen järjestys) Yleisempi tilanne: alkioiden hierarkia

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

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

Algoritmit 1. Luento 7 Ti Timo Männikkö

A TIETORAKENTEET JA ALGORITMIT

Algoritmit 2. Luento 4 To Timo Männikkö

Algoritmit 2. Luento 6 To Timo Männikkö

Algoritmit 2. Luento 6 Ke Timo Männikkö

Algoritmit 2. Luento 4 Ke Timo Männikkö

Algoritmit 2. Luento 5 Ti Timo Männikkö

Algoritmit 2. Luento 2 To Timo Männikkö

Algoritmit 2. Luento 2 Ke Timo Männikkö

v 1 v 2 v 3 v 4 d lapsisolmua d 1 avainta lapsen v i alipuun avaimet k i 1 ja k i k 0 =, k d = Sisäsolmuissa vähint. yksi avain vähint.

Algoritmit 1. Luento 8 Ke Timo Männikkö

1.1 Pino (stack) Koodiluonnos. Graafinen esitys ...

Algoritmit 2. Luento 7 Ti Timo Männikkö

Algoritmit 2. Luento 5 Ti Timo Männikkö

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

Kysymyksiä koko kurssista?

Algoritmit 1. Luento 6 Ke Timo Männikkö

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

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

1 Puu, Keko ja Prioriteettijono

Binäärihaun vertailujärjestys

Tietorakenteet, laskuharjoitus 7, ratkaisuja

811312A Tietorakenteet ja algoritmit, , Harjoitus 7, ratkaisu

Tietorakenteet, laskuharjoitus 6,

811312A Tietorakenteet ja algoritmit, , Harjoitus 5, Ratkaisu

811312A Tietorakenteet ja algoritmit II Perustietorakenteet

811312A Tietorakenteet ja algoritmit V Hash-taulukot ja binääriset etsintäpuut

TKT20001 Tietorakenteet ja algoritmit Erilliskoe , malliratkaisut (Jyrki Kivinen)

Algoritmi on periaatteellisella tasolla seuraava:

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

811312A Tietorakenteet ja algoritmit, , Harjoitus 5, Ratkaisu

A TIETORAKENTEET JA ALGORITMIT KORVAAVAT HARJOITUSTEHTÄVÄT 3, DEADLINE KLO 12:00

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

Kierros 4: Binäärihakupuut

CS-A1140 Tietorakenteet ja algoritmit

58131 Tietorakenteet Erilliskoe , ratkaisuja (Jyrki Kivinen)

ALGORITMIT 1 DEMOVASTAUKSET KEVÄT 2012

Algoritmit 2. Luento 9 Ti Timo Männikkö

58131 Tietorakenteet (kevät 2008) 1. kurssikoe, ratkaisuja

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

811312A Tietorakenteet ja algoritmit III Lajittelualgoritmeista

private TreeMap<String, Opiskelija> nimella; private TreeMap<String, Opiskelija> numerolla;

7. Tasapainoitetut hakupuut

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

B + -puut. Kerttu Pollari-Malmi

Muita linkattuja rakenteita

puuta tree hierarkkinen hierarchical

TIE Tietorakenteet ja algoritmit 261

Tietorakenteet ja algoritmit Hakurakenteet Ari Korhonen

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

Datatähti 2019 loppu

Algoritmit 1. Luento 4 Ke Timo Männikkö

Algoritmit 2. Demot Timo Männikkö

1 Erilaisia tapoja järjestää

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.

4. Joukkojen käsittely

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

Algoritmit 2. Luento 3 Ti Timo Männikkö

811312A Tietorakenteet ja algoritmit Kertausta kurssin alkuosasta

9 Erilaisia tapoja järjestää

Algoritmit 2. Luento 3 Ti Timo Männikkö

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

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

Tiraka, yhteenveto tenttiinlukua varten

Luku 8. Aluekyselyt. 8.1 Summataulukko

Tietorakenteet ja algoritmit - syksy

Algoritmit 1. Luento 12 Ke Timo Männikkö

Tietorakenteet ja algoritmit Johdanto Lauri Malmi / Ari Korhonen

Paikkatiedon hallinta ja analyysi 4. Paikkatiedon indeksointi

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

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

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

Algoritmit 1. Luento 5 Ti Timo Männikkö

Algoritmit 2. Luento 10 To Timo Männikkö

A TIETORAKENTEET JA ALGORITMIT

Tämä on helpompi ymmärtää, kun tulkitaan keko täydellisesti tasapainotetuksi binääripuuksi, jonka juuri on talletettu taulukon paikkaan

Algoritmit 1. Luento 12 Ti Timo Männikkö

8. Puna-mustat puut ja tietorakenteiden täydentäminen

Algebralliset tietotyypit ym. TIEA341 Funktio ohjelmointi 1 Syksy 2005

Algoritmit 1. Demot Timo Männikkö

Algoritmit 1. Demot Timo Männikkö

Paikkatiedon hallinta ja analyysi 4. Paikkatiedon indeksointi (jatkoa)

6. Hakupuut. Hakupuu (engl. search tree) on listaa huomattavasti edistyneempi tapa toteuttaa abstrakti tietotyyppi joukko

Luku 4. Tietorakenteet funktio-ohjelmoinnissa. 4.1 Äärelliset kuvaukset

2. Perustietorakenteet

13 Lyhimmät painotetut polut

Fibonacci-kasoilla voidaan toteuttaa samat operaatiot kuin binomikasoilla.

10. Painotetut graafit

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

Algoritmit 2. Luento 9 Ti Timo Männikkö

Ohjelmoinnin perusteet Y Python

Algoritmit 2. Demot Timo Männikkö

58131 Tietorakenteet ja algoritmit Uusinta- ja erilliskoe malliratkaisut ja arvosteluperusteet

Transkriptio:

TIE-20100 Tietorakenteet ja algoritmit 1 1 Puurakenteet http://imgur.com/l77fy5x Tässä luvussa käsitellään erilaisia yleisiä puurakenteita. ensin käsitellään tavallinen binäärihakupuu sitten tutustutaan monihaaraisiin puihin merkkijonopuun kautta tasapainotetaan binäärihakupuu muuttamalla se puna-mustaksi puuksi. monihaaraisista puista perehdytään vielä B-puuhun ja vilkaistaan lopuksi splay- ja AVL-puita. TIE-20100 Tietorakenteet ja algoritmit 3 Lisäksi binäärihakupuun (binary search tree) kaikilla solmuilla on seuraava ominaisuus: Jos l on mikä tahansa solmu x:n vasemmassa alipuussa ja r mikä tahansa solmu x:n oikeassa alipuussa, niin l.key x.key r.key esimerkiksi edellisen kuvan binääripuu on binäärihakupuu kappaleessa 3.1 esitelty keko on binääripuu muttei binäärihakupuu Useinmiten binääripuu esitetään linkitettynä rakenteena, jossa jokaisessa tietueessa on kentät key, left, right ja p (parent). lisäksi voi tietenkin olla oheisdataa TIE-20100 Tietorakenteet ja algoritmit 2 1.1 Tavallinen binäärihakupuu Binääripuu (binary tree) on äärellinen solmuista (node) koostuva rakenne, joka on joko tyhjä, tai sisältää yhden solmun nimeltä juuri (root), sekä kaksi binääripuuta nimeltä vasen alipuu (left subtree) ja oikea alipuu (right subtree) lapsettomia solmuja kutsutaan lehdiksi muut solmut ovat sisäsolmuja sisäsolmuj 18 juuri solmu on lastensa isä (parent) solmun esi-isiä (ancestor) ovat solmu itse, solmun isä, tämän isä jne. vastaavasti määritellään jälkeläinen (descendant) 3 5 6 8 13 25 15 9 14 23 lehtiä 22 3 26 32 33 35 TIE-20100 Tietorakenteet ja algoritmit 4 Binääripuun solmut voidaan käsitellä monessa eri järjestyksessä. esijärjestys (preorder) kutsu PREORDER-TREE-WALK.root) esimerkin käsittelyjärjestys on 18, 13, 8, 5, 3, 6, 9, 15, 14, 25, 22, 23, 30, 26, 33, 32, 35 PREORDER-TREE-WALK x) 1 if x = NIL then 2 käsittele alkio x 3 PREORDER-TREE-WALK x left) 4 PREORDER-TREE-WALK x right)

TIE-20100 Tietorakenteet ja algoritmit 5 välijärjestys (inorder) esimerkissä 3, 5, 6, 8, 9, 13, 14, 15, 18, 22, 23, 25, 26, 30, 32, 33, 35 binäärihakupuu tulee käsiteltyä avainten suuruusjärjestyksessä kuljettaessa puu välijärjestyksessä INORDER-TREE-WALK x) 1 if x = NIL then 2 INORDER-TREE-WALK x left) 3 käsittele alkio x 4 INORDER-TREE-WALK x right) TIE-20100 Tietorakenteet ja algoritmit 7 Etsintä binäärihakupuusta koko puusta haku R-TREE-SEARCH.root k) palauttaa osoittimen x solmuun, jolle x key = k, tai NIL, jos tällaista solmua ei ole R-TREE-SEARCH x k) 1 if x = NIL or k = x key then 2 return x etsitty avain löytyi) 3 if k < x key then jos etsitty on pienempi kuin avain...) 4 return R-TREE-SEARCH x left k)...etsitään vasemmasta alipuusta) 5 else muuten...) 6 return R-TREE-SEARCH x right k)...etsitään oikeasta alipuusta) Algoritmi suunnistaa juuresta alaspäin huonoimmassa tapauksessa pisimmän polun päässä olevaan lehteen asti. suoritusaika O h), missä h on puun korkeus lisämuistin tarve O h), rekursion vuoksi TIE-20100 Tietorakenteet ja algoritmit 6 jälkijärjestys (postorder) esimerkissä 3, 6, 5, 9, 8, 14, 15, 13, 23, 22, 26, 32, 35, 33, 30, 25, 18 POSTORDER-TREE-WALK x) 1 if x = NIL then 2 POSTORDER-TREE-WALK x left) 3 POSTORDER-TREE-WALK x right) 4 käsittele alkio x ajoaika Θ n) lisämuistin tarve = Θ(rekursion maksimisyvyys) = Θ h + 1) = Θ h) TIE-20100 Tietorakenteet ja algoritmit 8 Saman voi tehdä myös ilman rekursiota, mikä on suositeltavaa. tällöin lisämuistin tarve on vain Θ 1) ajoaika on yhä O h) TREE-SEARCH x k) 1 while x = NIL and k = x key do kunnes avain on löytynyt tai ollaan lehdessä) 2 if k < x key then jos etsitty on pienempi kuin avain...) 3 x := x left...siirrytään vasemmalle) 4 else muuten...) 5 x := x right...siirrytään oikealle) 6 return x palautetaan tulos)

TIE-20100 Tietorakenteet ja algoritmit 9 Minimi ja maksimi: minimi löydetään menemällä vasemmalle niin kauan kun se on mahdollista TREE-MINIMUM x) 1 while x left = NIL do 2 x := x left 3 return x maksimi löydetään vastaavasti menemällä oikealle niin kauan kun se on mahdollista TREE-MAXIMUM x) 1 while x right = NIL do 2 x := x right 3 return x molempien ajoaika on O h) ja lisämuistin tarve Θ 1) TIE-20100 Tietorakenteet ja algoritmit 11 TREE-SUCCESSOR x) 1 if x right = NIL then jos oikea alipuu löytyy...) 2 return TREE-MINIMUM x right)...etsitään sen minimi) 3 y := x p muuten lähdetään kulkemaan kohti juurta) 4 while y = NIL and x = y right do kunnes ollaan tultu vasemmasta lapsesta) 5 x := y 6 y := y p 7 return y palautetaan löydetty solmu) huomaa, että avainten arvoja ei edes katsota vrt. seuraajan löytäminen järjestetystä listasta ajoaika O h), lisämuistin tarve Θ 1) TREE-PREDECESSOR voidaan toteuttaa vastaavalla tavalla TIE-20100 Tietorakenteet ja algoritmit 10 Solmun seuraajaa ja edeltäjää kannattaa etsiä binäärihakupuusta puun rakenteen avulla mieluummin kuin avainten arvojen perusteella. tällöin SCAN-ALL toimii oikein, vaikka puussa olisi yhtä suuria avaimia tarvitaan siis algoritmi, joka etsii annettua solmua välijärjestyksessä seuraavan solmun sellainen voidaan rakentaa algoritmin TREE-MINIMUM avulla solmun seuraaja on joko oikean alipuun pienin alkio tai juureen vievällä polulla ensimmäinen solmu, jonka vasempaan alipuuhun solmu kuuluu jos edellä mainittuja solmuja ei löydy, on kysymyksessä puun viimeinen solmu TIE-20100 Tietorakenteet ja algoritmit 12 TREE-SUCCESSORIN ja TREE-MINIMUMIN avulla voidaan rakentaa toinen tapa selata puu läpi välijärjestyksessä. TREE-SCAN-ALL T ) 1 if.root = NIL then 2 x := TREE-MINIMUM.root) aloitetaan selaus puun minimistä) 3 else 4 x := NIL 5 while x = NIL do selataan niin kauan kun seuraajia löytyy) 6 käsittele alkio x 7 x := TREE-SUCCESSOR x) jokainen kaari kuljetaan kerran molempiin suuntiin TREE-SCAN-ALL selviää ajassa Θ n), vaikka kutsuukin TREE-SUCCESSORia n kertaa

TIE-20100 Tietorakenteet ja algoritmit 13 lisämuistin tarve Θ 1) TREE-SCAN-ALL on asymptoottisesti yhtä nopea, ja muistinkulutukseltaan asymptoottisesti parempi kuin INORDER-TREE-WALK vakiokertoimissa ei suurta eroa kannattaa valita TREE-SCAN-ALL, jos tietueissa on p-kentät TREE-SCAN-ALL sallii useat yhtäaikaiset selaukset, INORDER-TREE-WALK ei TIE-20100 Tietorakenteet ja algoritmit 15 Poisto on monimutkaisempaa, koska se voi kohdistua sisäsolmuun: TREE-DELETE T z) z osoittaa poistettavaa solmua) 1 if z left = NIL or z right = NIL then jos z:lla on vain yksi lapsi... ) 2 y := z... asetetaan z poistettavaksi tietueeksi) 3 else 4 y := TREE-SUCCESSOR z) muuten poistetaan z:n seuraaja) 5 if y left = NIL then otetaan talteen poistettavan ainoa lapsi) 6 x := y left 7 else 8 x := y right 9 if x = NIL then jos lapsi on olemassa... ) 10 x p := y p... linkitetään se poistettavan tilalle) 11 if y p = NIL then jos poistettava oli juuri... ) 12.root := x... merkitään x uudeksi juureksi) 13 else if y = y p left then sijoitetaan x poistettavan tilalle... ) 14 y p left := x... sen isän vasemmaksi... ) 15 else 16 y p right := x... tai oikeaksi lapseksi) 17 if y = z then jos poistettiin joku muu kuin z... ) 18 z key := y key... vaihdetaan poistetun ja z:n datat) 19 z satellitedata := y satellitedata 20 return y palautetaan osoitin poistettuun solmuun) TIE-20100 Tietorakenteet ja algoritmit 14 Lisäys binäärihakupuuhun: TREE-INSERT T z) z osoittaa käyttäjän varaamaa alustettua tietuetta) 1 y := NIL; x :=.root aloitetaan juuresta) 2 while x = NIL do laskeudutaan kunnes kohdataan tyhjä paikka) 3 y := x otetaan potentiaalinen isä-solmu talteen) 4 if z key < x key then siirrytään oikealle tai vasemmalle) 5 x := x left 6 else 7 x := x right 8 z p := y sijoitetaan löydetty solmu uuden solmun isäksi) 9 if y = NIL then 10.root := z puun ainoa solmu on juuri) 11 else if z key < y key then sijoitetaan uusi solmu isänsä vasemmaksi... ) 12 y left := z 13 else... tai oikeaksi lapseksi) 14 y right := z 15 z left := NIL; z right := NIL Algoritmi suunnistaa juuresta lehteen; uusi solmu sijoitetaan aina lehdeksi. ajoaika O h), lisämuistin tarve Θ(1) TIE-20100 Tietorakenteet ja algoritmit 16 Huom Rivillä 5 todellakin tiedetään, että y:llä on korkeintaan yksi lapsi. jos z:lla on vain yksi lapsi, y on z jos rivillä 4 kutsutaan TREE-SUCCESSORIA tiedetään, että z:lla on oikea alipuu, jonka minimi on y minimillä ei voi olla vasenta lasta Algoritmi näyttää monimutkaiselta, mutta rivin 4 TREE-SUCCESSORIA lukuunottamatta kaikki operaatiot ovat vakioaikaisia. ajoaika on siis O h) ja lisämuistin tarve Θ(1) Siis kaikki dynaamisen joukon perusoperaatiot saadaan binäärihakupuulla toimimaan ajassa O h) ja lisämuistilla Θ 1): SEARCH, INSERT, DELETE, MINIMUM, MAXIMUM, SUCCESSOR ja PREDECESSOR

TIE-20100 Tietorakenteet ja algoritmit 17 Kuinka korkeita binäärihakupuut yleensä ovat? Jos oletetaan, että alkiot on syötetty satunnaisessa järjestyksessä, ja jokainen järjestys on yhtä todennäköinen, pelkästään INSERTillä rakennetun binäärihakupuun korkeus on keskimäärin Θ lg n). kaikki operaatiot keskimäärin Θ lg n) Valitettavasti lopputulos ei ole läheskään yhtä tehokas, jos avaimet syötetään suuruusjärjestyksessä, kuten viereisestä kuvasta voi havaita. korkeus on n -1, surkeaa Ongelmaa ei pystytä ratkaisemaan järkevästi esimerkiksi satunnaistamalla, jos halutaan säilyttää kaikki dynaamisen joukon operaatiot. Ratkaisu on seuraavassa kappaleessa esiteltävä tasapainotus. 2 3 4 5 6 7 TIE-20100 Tietorakenteet ja algoritmit 19 1.2 Merkkijonopuu trie) Kun dynaamisen joukon alkiot ovat merkkijonoja, soveltuu merkkijonopuu binääripuuta paremmin niiden tallentamiseen. Merkkijonopuussa solmut ovat merkkejä. Kukin solmu edustaa siihen juuresta johtavan polun varrelta löytyvää merkkijonoa. solmun edustama merkkijono on siis sen isän edustama merkkijono + solmun sisältämä merkki solmun edustama merkkijono on kaikkien sen lasten edustamien merkkijonojen alkuosa Lisäksi kussakin solmussa on yksi bitti, joka kertoo, onko solmun edustama merkijono mukana joukossa vai ei. TIE-20100 Tietorakenteet ja algoritmit 18 Binäärihakupuita - kuten muitakin tietorakenteita - voi sovittaa uusiin tehtäviin lisäämällä uusia tehtävän kannalta olennaista tietoa sisältäviä kenttiä. tällöin perusoperaatiot tulee muokata ylläpitämään myös uusien kenttien sisältöä esimerkiksi lisäämällä solmuihin kenttä, joka kertoo solmun virittämän alipuun koon saadaan toteutettua funktio, joka palauttaa puun korkeuteen nähden lineaarisessa ajassa i:nnen alkion saadaan toteutettua funktio, joka puun korkeuteen nähden lineaarisessa ajassa kertoo, monesko kysytty alkio on suuruusjärjestyksessä ilman ylimääräistä kenttää algoritmit täytyisi toteuttaa huomattavasti tehottomammin puun alkioiden määrään nähden lineaarisessa ajassa TIE-20100 Tietorakenteet ja algoritmit 20 a b T a b a b a b T a b a b T a b T

TIE-20100 Tietorakenteet ja algoritmit 21 Kuvan esimerkkipuun aakkosto on a b}. koska juurisolmun totuusarvo on true, kuuluu sen edustama tyhjä merkkijono mukaan joukkoon pelkät a ja b eivät kuulu joukkoon, koska ne on merkitty falsella merkkijonot aa, aba ja ba kuuluvat joukkoon TRIE-SEARCH p A n) 1 for i := 1 to n do käydään lisättävän sanan merkkejä läpi) 2 if p C[A[i]] = NIL then jos valittu haara päättyy...) 3 return FALSE...tiedetään, ettei sanaa löydy) 4 p := p C[A[i]] siirrytään alaspäin) 5 return p bit palautetaan löydetyn solmun totuusarvo) Etsittävä merkkijono on taulukossa A[1 n] ja p osoittaa puun juureen. Solmut sisältävät taulukon C, jossa on osoitin C[a] jokaista merkkijonon mahdollista merkkiä a kohti, sekä bittikentän bit, joka ilmoittaa, kuuluuko merkkijono joukkoon vai ei. TIE-20100 Tietorakenteet ja algoritmit 23 TRIE-DELETE p A n) 1 for i := 1 to n do käydään poistettavan sanan merkkejä läpi) 2 if p C[A[i]] = NIL then jos valittu haara päättyy...) 3 return FALSE...tiedetään, ettei sanaa löydy) 4 P [i] := p otetaan solmun i isän osoite talteen) 5 p := p C[A[i]] siirrytään alaspäin) 6 p bit := FALSE asetetaan löydetyn solmun totuusarvoksi FALSE) 7 i := n 8 while i > 1 and Leafnode(p) and p bit = FALSE do 9 vapautetaan p:n osoittama alkio 10 p := P [i] jatketaan vapauttamista talteen otetusta isästä) 11 p C[A[i]] = NIL nollataan osoitin poistettuun solmuun) 12 i := i 1 13 return TRUE Puusta etsitään vapautettava merkkijono ja poistetaan se joukosta asettamalla bit arvoon FALSE. TIE-20100 Tietorakenteet ja algoritmit 22 Etsinnässä puuta laskeudutaan alaspäin kunnes kohdataan NIL-osoitin, jolloin sana ei ole puussa tai sana loppuu, jolloin palautetaan bit-kentän arvo TRIE-INSERT p A n) 1 for i := 1 to n do käydään lisättävän sanan merkkejä läpi) 2 if p C[A[i]] = NIL then tarvittaessa lisätään uusi solmu) 3 varaa uusi solmutietue ja alusta kunkin osoittimen uusi C[i] arvoksi NIL ja bit FALSE 4 p C[A[i]] := uusi linkitetään uusi solmu paikalleen) 5 p := p C[A[i]] siirrytään alaspäin) 6 p bit := TRUE asetetaan viimeisen solmun totuusarvoksi TRUE) Lisättäessä uutta alkiota puuhun laskeudutaan uuden merkkijonon mukaisesti kohti lehtisolmuja. jos kohdataan NIL-osoitin luodaan uusi solmu kun ollaan päästy sanan loppuun, käännetään solmun bit-kenttä arvoon TRUE sen merkiksi, että sana kuuluu joukkoon TIE-20100 Tietorakenteet ja algoritmit 24 Tämän jälkeen poistetaan ne solmut, jotka poisto on tehnyt turhiksi. koska trien solmuissa ei ole parent-osoittimia, talletetaan taulukkoon P laskeutumisen aikana kohdatut osoittimet Dynaamisen joukon operaatiot ovat trielle erittäin tehokkaita Riippumatta talletettujen merkkijonojen määrästä operaatiot ovat enintään lineaarisia käsiteltävän merkkijonon pituuteen nähden. Haittapuolena on runsas muistinkäyttö erityisesti jos erilaisten mahdollisten merkkien määrä on suuri. toisaalta jos talletettavilla merkkijonoilla on pitkiä yhteisiä alkuosia, tilaa jopa säästyy, koska yhteiset osat talletetaan vain kerran

TIE-20100 Tietorakenteet ja algoritmit 25 Merkkijonopuu sallii myös siihen talletettujen merkkijonojen tulostamisen aakkosjärjestyksessä tehokkaasti. Esimerkiksi matkapuhelimissa yleisesti käytetty ennakoiva tekstinsyöttö T9, on toteutettu trierakenteen avulla. erona tässä esitettyyn malliin on, että saman näppäimen takana olevat kirjaimet kuuluvat samaan solmuun lisäksi kullekin kirjaimelle on laskettu todennäköisyys, jonka perusteella päätetään, mikä merkkijono painalluksista todennäköisimmin muodostuu