Arbori 3-2
Fie G un graf orientat. G este un arbore cu radacina r, daca exista in G un varf r din care oricare alt varf poate fi ajuns printr-un drum unic.
Definitia este valabila si pentru cazul unui graf neorientat, alegerea unei radacini fiind insa in acest caz arbitrara: orice arbore este un arbore cu radacina, iar radacina poate fi fixata in oricare varf al sau. Aceasta, deoarece dintr-un varf oarecare se poate ajunge in oricare alt varf printr-un drum unic.
Cand nu va fi pericol de confuzie, vom folosi termenul "arbore", in loc de termenul corect "arbore cu radacina". Cel mai intuitiv este sa reprezentam un arbore cu radacina, ca pe un arbore propriu-zis. In Figura 3.1, vom spune ca beta este tatal lui delta si fiul lui alpha, ca beta si gamma sunt frati, ca delta este un descendent al lui alpha, iar alpha este un ascendent al lui delta. Un varf terminal este un varf fara descendenti. Varfurile care nu sunt terminale sunt neterminale. De multe ori, vom considera ca exista o ordonare a descendentilor aceluiasi parinte: beta este situat la stanga lui gamma, adica beta este fratele mai varstnic al lui gamma.
Orice varf al unui arbore cu radacina este radacina unui subarbore constand din varful respectiv si toti descendentii sai. O multime de arbori disjuncti formeaza o padure.
Intr-un arbore cu radacina vom adopta urmatoarele notatii. Adancimea unui varf este lungimea drumului dintre radacina si acest varf; inaltimea unui varf este lungimea celui mai lung drum dintre acest varf si un varf terminal; inaltimea arborelui este inaltimea radacinii; nivelul unui varf este inaltimea arborelui, minus adancimea acestui varf.
Reprezentarea unui arbore cu radacina se poate face prin adrese, ca si in cazul listelor inlantuite. Fiecare varf va fi memorat in trei locatii diferite, reprezentand informatia propriu-zisa a varfului (valoarea varfului), adresa celui mai varstnic fiu si adresa urmatorului frate. Pastrand analogia cu listele inlantuite, daca se cunoaste de la inceput numarul maxim de varfuri, atunci implementarea arborilor cu radacina se poate face prin tablouri paralele
Au fost studiate diferite tipuri de arbori binari, adica arbori pentru care e-gradul fiecarui nod este mai mic sau egal cu 2. Arborii care au e-gradul mai mare sau egal cu 2 se numesc arbori multicai.
Daca se doreste sa se prezinte descendenta unei persoane din punct de vedere al stramosilor, i se asociaza persoanei doi parinti, obtinandu-se un arbore binar.
Daca problema este abordata din punct de vedere al urmasilor, atunci o familie poate avea mai multi copii, rezultand noduri cu mai multe ramuri.
Se considera problema construirii si explorarii informatiei continute in arbori de mari dimensiuni; se considera si operatiile executate unor astfel de arbori.
Sa notam ca astfel de arbori sunt pastrati pe suporturi auxiliare; atunci nodurile arborelui sunt memorate pe un suport auxiliar si sunt transferate pe rand sau pe grupe in memoria centrala.
Structurile dinamice sunt cele utilizate eficient pentru implementarea unor astfel de arbori. In acest caz pointerii nodurilor nu vor mai indica adrese de memorie.
Utilizand un arbore cu 106 noduri, vor fi necesare aproximativ log2106 pasi pentru cautarea unor elemente.
Deoarece fiecare pas necesita un acces la memoria auxiliara rezulta necesitatea unei organizari care sa reduca numarul de accese.
Este stiut faptul ca dupa realizarea accesului la un anumit element al memoriei auxiliare este usor accesibil fiecare element al arborelui din zona respectiva. Acest lucru sugereaza ca un arbore poate fi divizat in subarbori ce pot fi reprezentati ca unitati la care accesul se realizeaza deodata. Subarborii in care sunt divizati arborii de mari dimensiuni si care au proprietatea de mai sus se numesc pagini.
Deci o pagina poate fi privita ca un nod de la care pot pleca oricate ramuri; in acest mod arborele binar poate fi transformat intr-un arbore multicai. Daca p este numarul de pagini, n numarul de noduri din arborele binar original, procesul de cautare a unui element va necesita log2p accese la memoria auxiliara, adica un numar mai mic de accese decat log2n.
Pentru descompunerea in pagini a unui arbore binar trebuie avute in vedere urmatoarele aspecte:
a) modul de grupare a cheilor intr-un arbore multicai;
b) modul de plasare a elementelor corespunzatoare diverselor chei;
c) tehnica de inserare sau eliminare a unei chei;
d) modul de aranjare a cheilor in cadrul unui nod.
Dintre toate modurile de organizare a arborilor multicai cel mai eficient este arborele 3-2, care reprezinta o varianta de arbore echilibrat; un nod al unui astfel de arbore poate avea cel mult 3 descendenti directi.