Zoekboom
Een zoekboom in de informatica is een boomstructuur die gebruikt wordt voor het vinden van specifieke waarden uit een verzameling. Een belangrijke eigenschap die een zoekboom van een gewone boom onderscheidt is het gegeven dat de waarde van een top groter moet zijn dan de waarden in de linkersubboom en kleiner dan de waarden in de rechtersubboom.[1]
Het voordeel van zoekbomen is hun efficiënte zoekoperatie, gegeven dat de boom redelijk gebalanceerd is. Dit wil zeggen dat de bladeren van de boom allemaal ongeveer even diep zitten. Er bestaan verschillende soorten zoekbomen; verschillende soorten hebben ook efficiënte toevoeg- en verwijderoperaties.
Zoekbomen worden vaak gebruikt om een associatieve array te implementeren. Dit kan door de sleutels van de sleutel/waarden-paren uit de array te gebruiken als waarden voor de toppen in de boom.
Soorten zoekbomen
bewerkenBinaire zoekboom
bewerkenEen binaire zoekboom is een zoekboom waarbij elke top hoogstens twee kinderen heeft. De linkerdeelboom bevat alle waarden die kleiner zijn dan de waarde van de huidige top, terwijl de rechterdeelboom alle grotere waarden bevat.
Het slechtste geval qua tijdscomplexiteit voor het opzoeken in een binaire zoekboom is de diepte van de boom. In het optimale geval, bij een gebalanceerde boom, gaat het om voor een boom met elementen.
B-boom
bewerkenB-bomen zijn een generalisatie van binaire zoekbomen, waarbij een top een variabel aantal kinderen kan hebben. Hoewel het bereik van de kinderen vastligt, zijn deze kinderen niet altijd aanwezig. Hierdoor is het mogelijk dat B-bomen wat geheugen kunnen verspillen. Het voordeel is dan dat B-bomen niet zo vaak opnieuw gebalanceerd moeten worden als andere zelfbalancerende bomen.
Vanwege het variabele bereik van hun toppen zijn B-bomen geoptimaliseerd voor het lezen van grote blokken data. Ze worden ook vaak gebruikt in databanken.
(a, b)-boom
bewerkenEen -boom is een zoekboom waarvan alle bladeren dezelfde diepte hebben. Elke top heeft minstens en maximaal kinderen, terwijl de wortel tussen 2 en kinderen heeft. De waarden voor a en b kunnen bepaald worden met volgende formule:[2]
Trie
bewerkenEen trie is een categorie zoekbomen, waarbij de waarden meestal tekenreeksen zijn. Ook typerend is dat toppen geen waarde opslaan; de positie in de boom definieert de waarde van de top. Onder tries vallen o.a. ook suffixbomen en radixbomen.
Intervalboom
bewerkenEen intervalboom is een zoekboom die gebruikt wordt om intervallen op te slaan. Het laat toe om op efficiënte wijze alle intervallen die overlappen met een gegeven interval of punt te vinden. Deze soort (en zijn varianten) wordt vaak gebruikt bij ruimtelijke problemen, zoals het vinden van alle straten binnen een bepaald vierkant op een kaart.
Zie ook
bewerkenDit artikel of een eerdere versie ervan is een (gedeeltelijke) vertaling van het artikel Search tree op de Engelstalige Wikipedia, dat onder de licentie Creative Commons Naamsvermelding/Gelijk delen valt. Zie de bewerkingsgeschiedenis aldaar.
- ↑ (en) Black, Paul, search tree. Dictionary of Algorithms and Data Structures (14 december 2005). Geraadpleegd op 28 maart 2019.
- ↑ (en) Ray, Toal, (a,b) Trees[dode link]. Geraadpleegd op 28 maart 2019.