In dit artikel gaan we de fascinerende wereld van Boom (datastructuur) verkennen. Van de impact ervan op de hedendaagse samenleving tot de relevantie ervan in de geschiedenis, Boom (datastructuur) heeft door de jaren heen de aandacht van veel mensen getrokken. Door middel van gedetailleerde analyse zullen we de verschillende facetten van Boom (datastructuur) onderzoeken, de mysteries ervan ontrafelen en de ware betekenis ervan ontdekken. Met een kritisch en objectief perspectief zullen we ons onderdompelen in de meerdere dimensies van Boom (datastructuur), in een poging het belang en de invloed ervan op verschillende gebieden van het leven te begrijpen. Bereid je dus voor op een spannende reis terwijl we dieper ingaan op het onderwerp Boom (datastructuur) en ontdekken wat het allemaal te bieden heeft.
Een boom of boomstructuur is een datastructuur in de informatica die een bijzonder geval van een graaf is. Een boom bestaat uit een knoop(punt) of vertex die de stam (ook wel wortel) genoemd wordt en die het ingangspunt is voor de in de boom opgeslagen informatie. In deze wortelknoop zitten nul of meer pointers die naar andere knooppunten verwijzen. Ieder knooppunt behalve de wortel heeft precies een ouder en nul of meer kinderen. Verwijzingen gaan dus nooit tussen de kinderen onderling maar alleen van ouder naar kind; in een wat uitgebreidere versie eventueel ook van kind naar ouder (bidirectionele graaf). In een boom bestaan geen cirkelpaden en is er altijd precies 1 pad van de wortel naar een willekeurige knoop. Een knoop die zelf geen kinderen heeft noemt men een blad.
Een binaire of dichotome boom is een boomstructuur waarbij iedere knoop maximaal twee kinderen heeft. Een complete binaire boom is een boomstructuur waarbij al zijn niveaus behalve eventueel de laatste volledig gevuld zijn en alle knopen op het laatste niveau aan de linkerzijde zijn. Iedere boom kan op vrij eenvoudige wijze in een binaire boom worden getransformeerd. Ook voor iedere graaf die geen niet-verbonden vertices heeft kan een boom worden gemaakt. Een geordende boom is een boomstructuur waarbij de kinderen een gedefinieerde volgorde hebben.
Voor boomstructuren bestaat een groot aantal goed bekende algoritmen, bijvoorbeeld om iets in een geordende boom op te zoeken, om een nieuw element in een geordende boom aan te brengen of te verwijderen, of om een niet-geordende boom te sorteren (om te zetten in een geordende boom). Als een boom specifieke eigenschappen heeft, kunnen deze algoritmen vaak nog verfijnd (en dus meestal ook versneld) worden. Bomen kunnen gebruikt worden om allerlei problemen in de informatica voor te stellen.