Arvores b

horaciojcfilho1 1,258 views 18 slides Jul 09, 2013
Slide 1
Slide 1 of 18
Slide 1
1
Slide 2
2
Slide 3
3
Slide 4
4
Slide 5
5
Slide 6
6
Slide 7
7
Slide 8
8
Slide 9
9
Slide 10
10
Slide 11
11
Slide 12
12
Slide 13
13
Slide 14
14
Slide 15
15
Slide 16
16
Slide 17
17
Slide 18
18

About This Presentation

No description available for this slideshow.


Slide Content

Árvore B
Árvore B é uma estrutura de dados que utiliza o
recurso de manter mais de uma chave em cada nó da
estrutura.
Ela proporciona uma organização de ponteiros de tal
forma que as operações buscas, inserções e remoções
são executadas rapidamente.
As árvores B são largamente utilizadas como forma de
armazenamento em memória secundária. Diversos
sistemas comerciais de Banco de dados, por exemplo,
as empregam.

Árvore B
Árvores B são árvores enraizadas balanceadas, com
balanço perfeito. Sua construção assegura que as folhas
se encontram em um mesmo nível, não importando a
ordem de entrada dos dados.
Um nó de uma árvore B é chamado página.
Cada página, exceto a raiz, deve ter entre d e 2d
elementos.
A raiz tem pelo menos dois descendentes diretos.

Representando Árvores B
Numa árvore binária, cada nó contém um valor (chave)
e duas sub-árvores (filhos) que podem ser nulas:
Numa árvore 2-3, árvore B de ordem 1, um nó pode ter
até 2 chaves e 3 filhos:
9
Valores menores que 9 Valores maiores que 9
9 13 25

Representando Árvores B
Um nó de uma árvore B, nó M-ário (nó alargado),
possui M descendentes diretos e M-1 elementos.
Os elementos dentro de um nó estão ordenados.
O ponteiro situado entre dois elementos a e b aponta
para a sub-árvore que contém todos os elementos entre
a e b.

Representando Árvores B
Os ponteiros para os descendentes e os elementos
dentro de um nó são armazenados em arrays.
Os descendentes têm índices entre 0 e M-1.
Os elementos têm índices entre 0 e M-2.

Representando Árvores Binárias
Nó de uma árvore binária:
typedef struct No *Ponteiro_No;
typedef struct No {
int chave;
Ponteiro_No filho_esquerdo ;
Ponteiro_No filho_direito ;
} No;
Pode se acrescentar informações relativas ao elemento
armazenado ou uma lista de elementos armazenados
com a mesma chave.
Chave do nó
Referências para os nós
descendentes

Representando Árvores AVL
No nó de uma árvore AVL, acrescenta-se o balance:
typedef struct No *Ponteiro_No;
typedef struct No {
int chave;
int balance;
Ponteiro_No filho_esquerdo ;
Ponteiro_No filho_direito ;
} No;
Pode se acrescentar informações relativas ao elemento
armazenado ou uma lista de elementos armazenados
com a mesma chave.
Chave do nó
Referências para os nós
descendentes
Balance: diferença de
alturas

Representando Árvores B
Nó (página) de uma árvore B:
typedef struct No *Ponteiro_No;
typedef struct No {
int n;
int chaves[M-1];
Ponteiro_No filhos[M] ;
} No;
Número de elementos no nó
Chaves do nó
Referências para os nós
descendentes
Pode se acrescentar informações relativas ao elemento
armazenado ou uma lista de elementos armazenados
com a mesma chave.

Representando Árvores B
Para criar a árvore propriamente dita, criaremos a classe
Arvore, que manipula objetos do tipo No.
typedef struct Arvore {
Ponteiro_No raiz;
} Arvore;
Arvore *createBTree() {
Arvore *ret =
(Arvore *) malloc(sizeof(Arvore));
ret->raiz = NULL;
return ret;
}

Busca
Algoritmo Simplificado:
Se x < C
0
; seguir F
0
Se C
i-1
< x < C
i
; seguir F
i
Se x > C
n-1
; o caminho será indicado por F
n
C0 C1 ... Cn-1
F0 F1 F2...Fn-1 Fn
Mesmo índice = à esquerda = menor
Índice mais um = à direita = maior

Busca
int busca ( int k, Ponteiro_No p ) {
if ( p == NULL ) return 0;
else {
int i = 0;
while ( i < p->n-1 && k > p->chaves[i] )
i++;
if ( k == p->chaves[i] )
return 1; // achei
else if ( k < p->chaves[i] )
return busca ( k, p->filhos[i] ) ;
else // k > p->chaves[i]
return busca ( k, p->filhos[i+1] ) ;
}
}
(i ≠ 0) p->chaves[i-1] < k

Inserção
Um elemento só é inserido na folha.
Casos:
•Se a página onde o elemento for inserido tiver menos de 2d
chaves, então o elemento será inserido nessa página;
•Caso contrário, a página ficará com 2d+1 chaves, sendo
necessário realizar uma cisão. O elemento do meio será
promovido à página diretamente acima. Os elementos
menores ficarão numa página à esquerda desse elemento e
os maiores à direita. Se esse procedimento resultar em outra
página com 2d+1 chaves, realizar-se-á novamente o mesmo
procedimento, podendo chegar até a raiz.

Inserção
Inserção do elemento 6 em uma árvore com d = 1 (Árvore 2-3)
3 5
2 4 7 8
3 5
2 4 6 7 8

Inserção
3 5 7
2 4 6 8
2 4 6 8
73
5

Inserção
O algoritmo de inserção é recursivo.
Pré-Work:
•Quando estamos numa página não-nula da árvore, tenta-
se inserir no nível abaixo, escolhendo o descendente
adequado (Busca).
•Quando estamos numa página nula, neste caso chegou-se
ao fim da árvore, ultrapassando-se mesmo o nível mais
baixo e devolve-se simplesmente o elemento ao nó superior,
simulando uma promoção (Caso Base).

Inserção
Pós-Work:
•Se houver uma promoção, o elemento promovido deve ser
inserido na página atual.
•Se a página atual estiver cheia, a página deve ser partida e
o elemento mediano promovido.
Caso especial:
Se estamos na raiz, se houver uma promoção, deve ser criada uma
nova raiz tendo como único elemento aquele que foi promovido e
como descendentes os dois nós resultantes da partição da antiga
raiz.

Applet
http://slady.net/java/bt/view.php
Tags