Você está na página 1de 125

Arvores B

MO637 Complexidade de Algoritmos II


14 de setembro de 2007
MO637 Complexidade de Algoritmos II

Arvores B
Overview
MO637 Complexidade de Algoritmos II

Arvores B
Overview
Sao arvores balanceadas, desenvolvidas para otimizar o acesso
a armazenamento secundario
MO637 Complexidade de Algoritmos II

Arvores B
Overview
Sao arvores balanceadas, desenvolvidas para otimizar o acesso
a armazenamento secundario
Os n os da arvore B podem ter muitos lhos. Esse fator de
ramica cao e determinante para reduzir o n umero de acessos
a disco.

Arvores B sao balanceadas, ou seja, sua altura e
O(lg(n))
MO637 Complexidade de Algoritmos II

Arvores B
Overview
Sao arvores balanceadas, desenvolvidas para otimizar o acesso
a armazenamento secundario
Os n os da arvore B podem ter muitos lhos. Esse fator de
ramica cao e determinante para reduzir o n umero de acessos
a disco.

Arvores B sao balanceadas, ou seja, sua altura e
O(lg(n))

Arvores B sao generaliza c oes de arvores binarias balanceadas


MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
Atualmente o armazenamento estavel e feito em discos
magneticos, e o custo de cada acesso (da ordem de mili
segundos) e muito alto quando comparado ao acesso `a
mem oria RAM (ordem de nano segundos)
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
Atualmente o armazenamento estavel e feito em discos
magneticos, e o custo de cada acesso (da ordem de mili
segundos) e muito alto quando comparado ao acesso `a
mem oria RAM (ordem de nano segundos)
Toda vez que um acesso e feito, deve-se aproveita-lo da
melhor maneira possvel, trazendo o maximo de informa cao
relevante
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
A quantidade de dados utilizados numa arvore B obviamente
nao cabem na mem oria de uma s o vez, por isso e necessario
pagina-la
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
A quantidade de dados utilizados numa arvore B obviamente
nao cabem na mem oria de uma s o vez, por isso e necessario
pagina-la
Especializa c oes sao feitas de acordo com as necessidades da
aplica cao. O fator de ramica cao, por exemplo, pode variar de
3 a 2048 por exemplo (dependendo do buer dos discos e do
tamanho das paginas de mem oria alocados pelo SO)
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
Na grande maioria dos sistemas, o tempo de execu cao de um
algoritmo de arvore-B e determinado pelas leituras e escritas
no disco
MO637 Complexidade de Algoritmos II

Arvores B
Armazenamento Secundario
Na grande maioria dos sistemas, o tempo de execu cao de um
algoritmo de arvore-B e determinado pelas leituras e escritas
no disco
Um fator de ramica cao alto reduz drasticamente a altura da
arvore. Tomemos o exemplo:
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
Consideraremos que o os dados dos registros sejam guardados
junto com a chave da arvore. Se estivessemos usando uma arvore
B+, os registros cariam todos nas folhas:
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
Seja T uma arvore-B com raiz (root[T]). Ela possuira entao as
seguintes propriedades:
1. Todo o n o X tem os seguintes campos:
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
Seja T uma arvore-B com raiz (root[T]). Ela possuira entao as
seguintes propriedades:
1. Todo o n o X tem os seguintes campos:
a. n[x], o n umero de chaves atualmente guardadas no n o x,
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
Seja T uma arvore-B com raiz (root[T]). Ela possuira entao as
seguintes propriedades:
1. Todo o n o X tem os seguintes campos:
a. n[x], o n umero de chaves atualmente guardadas no n o x,
b. As n[x] chaves, guardadas em ordem crescente, tal que
key
1
[x] key
2
[x] key
n[x]
[x],
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
Seja T uma arvore-B com raiz (root[T]). Ela possuira entao as
seguintes propriedades:
1. Todo o n o X tem os seguintes campos:
a. n[x], o n umero de chaves atualmente guardadas no n o x,
b. As n[x] chaves, guardadas em ordem crescente, tal que
key
1
[x] key
2
[x] key
n[x]
[x],
c. leaf [x], Um valor booleano, TRUE se x e uma folha e
FALSE se x e um n o interno
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
2. Cada n o interno x tambem contem n[x] + 1 apontadores
c
1
[x], c
2
[x], ...,c
n[x]+1
[x] para os lhos. As folhas tem seu
apontador nulo
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
2. Cada n o interno x tambem contem n[x] + 1 apontadores
c
1
[x], c
2
[x], ...,c
n[x]+1
[x] para os lhos. As folhas tem seu
apontador nulo
3. As chaves key
i
[x] separam os intervalos de chaves
guardadas em cada sub-arvore: se k
i
e uma chave guardada
numa sub-arvore com raiz c
i
[x], entao:
k
1
key
1
[x] k
2
key
2
[x] ... key
n[x]
[x] k
n[x]+1
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
2. Cada n o interno x tambem contem n[x] + 1 apontadores
c
1
[x], c
2
[x], ...,c
n[x]+1
[x] para os lhos. As folhas tem seu
apontador nulo
3. As chaves key
i
[x] separam os intervalos de chaves
guardadas em cada sub-arvore: se k
i
e uma chave guardada
numa sub-arvore com raiz c
i
[x], entao:
k
1
key
1
[x] k
2
key
2
[x] ... key
n[x]
[x] k
n[x]+1
4. Todas as folhas tem a mesma profundidade, que e a altura
da arvore: h
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
5. Existem limites superiores e inferiores para o n umero de chaves
num n o. Estes limites podem ser expressados em termos de um
inteiro xo t 2 chamado grau mnimo:
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
5. Existem limites superiores e inferiores para o n umero de chaves
num n o. Estes limites podem ser expressados em termos de um
inteiro xo t 2 chamado grau mnimo:
a. Todo n o que nao seja raiz deve ter pelo menos t 1 chaves.
Todo n o interno que nao a raiz tem portanto t lhos. Se a
arvore for nao vazia, a raiz deve ter pelo menos uma chave
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
5. Existem limites superiores e inferiores para o n umero de chaves
num n o. Estes limites podem ser expressados em termos de um
inteiro xo t 2 chamado grau mnimo:
a. Todo n o que nao seja raiz deve ter pelo menos t 1 chaves.
Todo n o interno que nao a raiz tem portanto t lhos. Se a
arvore for nao vazia, a raiz deve ter pelo menos uma chave
b. Cada n o pode conter no maximo 2t 1 chaves. Portanto,
um n o interno, pode ter no maximo 2t lhos. O n o e
considerado cheio quando ele contem exatamente 2t 1
chaves
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
Podemos ver o poder da arvore-B quando comparada a outros
tipos de arvores balanceadas com altura O(log
2
(n)). No caso
da arvore-B a base do logaritmo e proporcional ao fator de
ramica cao
MO637 Complexidade de Algoritmos II

Arvores B
Deni cao da arvore-B
Podemos ver o poder da arvore-B quando comparada a outros
tipos de arvores balanceadas com altura O(log
2
(n)). No caso
da arvore-B a base do logaritmo e proporcional ao fator de
ramica cao
Por exemplo, se tivermos um fator de ramica cao 1000 e
aproximadamente 1 milhao de registros, precisaremos de
apenas log
1000
(10
6
)

= 3 idas ao disco
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
A busca em uma arvore-B e similar `a busca em uma arvore
binaria, s o que ao inves de uma bifurca cao em cada n o, temos
varios caminhos a seguir de acordo com o n umero de lhos do
n o
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
A busca em uma arvore-B e similar `a busca em uma arvore
binaria, s o que ao inves de uma bifurca cao em cada n o, temos
varios caminhos a seguir de acordo com o n umero de lhos do
n o
O algoritmo de busca na arvore e uma generaliza cao da busca
em uma arvore binaria
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
A fun cao B-TREE-SEARCH recebe o apontador para o n o
raiz (x) e a chave k sendo procurada
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
A fun cao B-TREE-SEARCH recebe o apontador para o n o
raiz (x) e a chave k sendo procurada
Se a chave k pertencer `a arvore o algoritmo retorna o n o ao
qual ela pertence e o ndice dentro do n o correspondente `a
chave procurada, caso contrario, retorna NIL
MO637 Complexidade de Algoritmos II

Arvores B
B-TREE-SEARCH
B-TREE-SEARCH(x, k)
1 i 1
2 while i n[x] and k > key
i
[x] do
3 i i + 1
4 if i n[x] and k = key
i
[x] then
5 return (x, i)
6 if leaf [x] then
7 return NIL
8 else DISK-READ(c
i
[x])
9 return B-TREE-SEARCH(c
i
[x], k)
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
Como dito anteriormente, o n umero de acessos a disco e
O(log
t
(n)) onde n e o n umero de chaves na arvore
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento
Como dito anteriormente, o n umero de acessos a disco e
O(log
t
(n)) onde n e o n umero de chaves na arvore
Como em cada n o, e feita uma busca linear, temos um gasto
de O(t) em cada n o. Sendo assim, o tempo total e de
O(t log
t
(n))
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento: Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento: Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento: Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento: Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Busca por Elemento: Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao de Elemento
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao de Elemento
A inser cao nas arvores-B sao relativamente mais complicadas,
pois, precisamos inserir a nova chave no n o correto da arvore,
sem violar suas propriedades
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao de Elemento
A inser cao nas arvores-B sao relativamente mais complicadas,
pois, precisamos inserir a nova chave no n o correto da arvore,
sem violar suas propriedades
Como proceder se o n o estiver cheio?
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao de Elemento
A inser cao nas arvores-B sao relativamente mais complicadas,
pois, precisamos inserir a nova chave no n o correto da arvore,
sem violar suas propriedades
Como proceder se o n o estiver cheio?
Caso o n o esteja cheio, devemos separar (split) o n o ao redor
do elemento mediano, criando 2 novos n os que nao violam as
deni c oes da arvore
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao de Elemento
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao de Elemento
O elemento mediano e promovido, passando a fazer parte do
n o pai daquele n o
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao de Elemento
O elemento mediano e promovido, passando a fazer parte do
n o pai daquele n o
A inser cao e feita em um unico percurso na arvore, a partir da
raiz ate uma das folhas
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split)
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split)
O procedimento B-TREE-SPLIT-CHILD recebe como
parametros um n o interno (nao cheio) x um ndice i e um n o
y tal que Y = c
i
[x] e um lho de x que esta cheio
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split)
O procedimento B-TREE-SPLIT-CHILD recebe como
parametros um n o interno (nao cheio) x um ndice i e um n o
y tal que Y = c
i
[x] e um lho de x que esta cheio
O procedimento entao, separa o n o ao redor do elemento
mediano, copiando os elementos maiores que ele em z,
deixando os menores em y, ajusta o contador de elementos de
z e y para t 1, e promove o elemento mediano
MO637 Complexidade de Algoritmos II

Arvores B
B-TREE-SPLIT-CHILD
B-TREE-SPLIT-CHILD(x, i, y)
1 z ALLOCATE-NODE()
2 leaf [z] leaf [y]
3 n[z] t 1
4 for j 1 to t 1 do
5 key
j
[z] key
j +t
[y]
6 if not leaf [y] then
7 for j 1 to t do
8 c
j
[z] c
j +t
[y]
9 n[y] t 1
10 for j n[x] + 1 downto i + 1 do
11 c
j +1
[x] c
j
[x]
(continua)
MO637 Complexidade de Algoritmos II

Arvores B
B-TREE-SPLIT-CHILD
B-TREE-SPLIT-CHILD(cont.)
12 c
i +1
[x] z
13 for j n[x] downto i do
14 key
j +1
[x] key
j
[x]
15 key
i
[x] key
t
[y]
16 n[x] n[x] + 1
17 DISK-WRITE(y)
18 DISK-WRITE(z)
19 DISK-WRITE(x)
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split): Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split): Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split): Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split): Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split): Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Separa cao de No (Split): Exemplo
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao com Split
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao com Split
Dessa maneira, em uma unica passagem pela arvore, da raiz
`as folhas, inserimos uma determinada chave, dividindo (splits)
cada n o da arvore que encontrarmos no caminho, caso o n o
esteja cheio
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao com Split
Dessa maneira, em uma unica passagem pela arvore, da raiz
`as folhas, inserimos uma determinada chave, dividindo (splits)
cada n o da arvore que encontrarmos no caminho, caso o n o
esteja cheio
O c odigo a seguir faz uso de B-TREE-INSERT-NONFULL:
MO637 Complexidade de Algoritmos II

Arvores B
B-TREE-INSERT
B-TREE-INSERT(T, k)
1 r root[T]
2 if n[r ] = 2t 1 then
3 s ALLOCATE-NODE()
4 root[T] s
5 leaf [s] FALSE
6 n[s] 0
7 c
1
[s] r
8 B-TREE-SPLIT-CHILD(s, 1, r)
9 B-TREE-INSERT-NONFULL(s, k)
10 else B-TREE-INSERT-NONFULL(r, k)
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao com Split
B-TREE-INSERT-NONFULL insere a chave k no n o x, caso este
seja uma folha, caso contrario, procura o lho adequado e desce `a
ele recursivamente ate encontrar a folha onde deve inserir k
MO637 Complexidade de Algoritmos II

Arvores B
B-TREE-INSERT-NONFULL
B-TREE-INSERT-NONFULL(x, k)
1 i n[x]
2 if leaf [x] then
3 while i 1 and k < key
i
[x] do
4 key
i +1
[x] key
i
[x]
5 i i 1
6 key
i +1
[x] k
7 n[x] n[x] + 1
8 DISK-WRITE(x)
9 else while i 1 and k < key
i
[x] do
10 i i 1
11 i i + 1
12 DISK-READ(c
i
[x])
(continua)
MO637 Complexidade de Algoritmos II

Arvores B
B-TREE-INSERT-NONFULL
B-TREE-INSERT-NONFULL(cont.)
13 if n[c
i
[x]] = 2t 1 then
14 B-TREE-SPLIT-CHILD(x, i , c
i
[x])
15 if k > key
i
[x] then
16 i i + 1
17 B-TREE-INSERT-NONFULL(c
i
[x], k)
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao com Split
MO637 Complexidade de Algoritmos II

Arvores B
Inser cao com Split
Logo, o procedimento de inser cao leva O(t log
t
(n)), onde t
e o tamanho da pagina da arvore e n e o n umero total de
elementos
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
A remo cao de uma chave e analoga `a inser cao, porem com
alguns complicadores, ja que uma chave pode ser removida de
qualquer n o, seja ele raiz ou nao
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
A remo cao de uma chave e analoga `a inser cao, porem com
alguns complicadores, ja que uma chave pode ser removida de
qualquer n o, seja ele raiz ou nao
Assim como na inser cao, precisamos garantir que, ao
removermos a chave as propriedades da arvore-B nao sejam
violadas
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
A remo cao de uma chave e analoga `a inser cao, porem com
alguns complicadores, ja que uma chave pode ser removida de
qualquer n o, seja ele raiz ou nao
Assim como na inser cao, precisamos garantir que, ao
removermos a chave as propriedades da arvore-B nao sejam
violadas
Da mesma maneira que tivemos de garantir que um n o nao se
tornasse grande demais na inser cao, devemos garantir que ele
nao torne-se pequeno demais, ou seja, deve sempre ter pelo
menos t 1 elementos
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Sendo assim, seguiremos para os casos de remo cao de chaves
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Sendo assim, seguiremos para os casos de remo cao de chaves
Existem 6 casos possveis para a remo cao de uma chave de
uma arvore-B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Sendo assim, seguiremos para os casos de remo cao de chaves
Existem 6 casos possveis para a remo cao de uma chave de
uma arvore-B:
Caso 1. Se a chave k estiver numa folha da arvore e a folha
possui pelo menos t chaves,remove-se a chave da arvore
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso1:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso1:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso1:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso1:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso1:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 2. Se a chave k esta num n o interno x o seguinte deve ser
feito:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 2. Se a chave k esta num n o interno x o seguinte deve ser
feito:
a. Se o lho y que precede k no n o x possui pelo menos t
chaves, encontre o predecessor k

de k na sub-arvore com raiz


em y. Remova k

do n o lho e substitua k por k

no n o atual
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 2. Se a chave k esta num n o interno x o seguinte deve ser
feito:
a. Se o lho y que precede k no n o x possui pelo menos t
chaves, encontre o predecessor k

de k na sub-arvore com raiz


em y. Remova k

do n o lho e substitua k por k

no n o atual
b. Simetricamente, se o lho z que sucede k no n o x possui
pelo menos t chaves, encontre o sucessor k

de k na
sub-arvore com raiz em z. Remova k

do n o lho e substitua
k por k

no n o atual
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 A/B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 A/B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 A/B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 A/B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 A/B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 2(cont.) Se a chave k esta num n o interno x o seguinte deve
ser feito:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 2(cont.) Se a chave k esta num n o interno x o seguinte deve
ser feito:
c. Caso ambos y e z possuem somente t 1 chaves, copie
todos os elementos de z em y , libere a mem oria ocupada por
z e remova o apontador em x e remova k de x.
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 C:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 C:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 C:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso2 C:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 3 Se a chave k nao esta presente no n o interno x, determine
a sub-arvore c
i
[x] apropriada que deve conter k. Caso c
i
[x] possuir
somente t 1 chaves, proceder da seguinte maneira:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 3 Se a chave k nao esta presente no n o interno x, determine
a sub-arvore c
i
[x] apropriada que deve conter k. Caso c
i
[x] possuir
somente t 1 chaves, proceder da seguinte maneira:
a. Se c
i
[x] possui pelo menos t 1 chaves mas possui um
irmao adjascente com pelo menos t chaves copie para c
i
[x]
uma chave extra, movendo uma chave de x para c
i
[x] em
seguida movendo uma chave de um dos irmaos adjascentes a
c
i
[x] de volta para x e ajustando o apontador para o n o
correspondente
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 A:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 A:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 A:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 A:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 A:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 3(cont.) Se a chave k nao esta presente no n o interno x,
determine a sub-arvore c
i
[x] apropriada que deve conter k. Caso
c
i
[x] possuir somente t 1 chaves, proceder da seguinte maneira:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso 3(cont.) Se a chave k nao esta presente no n o interno x,
determine a sub-arvore c
i
[x] apropriada que deve conter k. Caso
c
i
[x] possuir somente t 1 chaves, proceder da seguinte maneira:
b. Se c
i
[x] e ambos os seus irmaos esquerdo e direito
possuem t 1 chaves, una c
i
[x] com um dos irmaos o que
envolve mover uma chave de x para o novo n o que acabou de
ser formado, sendo que x e o elemento mediano daquele n o
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 B:
MO637 Complexidade de Algoritmos II

Arvores B
Remo cao de Chaves
Caso3 B:
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Sabemos que antes da remo cao, e feita uma busca por
elemento na arvore, o que gasta O(t log
t
(n)), onde t e o
tamanho da pagina da arvore e n e o n umero total de
elementos
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Sabemos que antes da remo cao, e feita uma busca por
elemento na arvore, o que gasta O(t log
t
(n)), onde t e o
tamanho da pagina da arvore e n e o n umero total de
elementos
No pior caso, teremos todas as paginas da arvore com t-1
elementos pois esse e o limite inferior para cada pagina. Da
teremos o seguinte:
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Somente os casos 2c e 3b poderao ocorrer e para qualquer um
deles teremos o seguinte cenario:
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Somente os casos 2c e 3b poderao ocorrer e para qualquer um
deles teremos o seguinte cenario:
Se o caso 2c ocorrer, teremos o no que perdeu a chave com
t 2 chaves e t 1 lhos pois ja ocorreu um merge. Se for o
caso 3c o pai tera t 2 chaves e o elemento que perdeu o n o
tera t chaves por causa do merge
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Somente os casos 2c e 3b poderao ocorrer e para qualquer um
deles teremos o seguinte cenario:
Se o caso 2c ocorrer, teremos o no que perdeu a chave com
t 2 chaves e t 1 lhos pois ja ocorreu um merge. Se for o
caso 3c o pai tera t 2 chaves e o elemento que perdeu o n o
tera t chaves por causa do merge
Em qualquer um dos dois a rea cao disparada para corrigir a
arvore sera a mesma pois isso encaixa o n o com t 2 chaves
na situa cao do caso 3b. Ou seja, uma chave sera rebaixada da
pagina pai para ele, e um merge dele com um dos irmaos sera
feito
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Agora, o n o pai e que possui t 2 chaves repetindo a situa cao
anterior. Ou seja a opera cao propaga-se num determinado
subconjunto de paginas ate chagar `a raiz
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Agora, o n o pai e que possui t 2 chaves repetindo a situa cao
anterior. Ou seja a opera cao propaga-se num determinado
subconjunto de paginas ate chagar `a raiz
Como os merge copiam t 1 elementos a cada nvel da arvore
teremos uma complexidade de O((t 1) log
t
(n)) para os
merge onde log
t
(n) e a altura da arvore
MO637 Complexidade de Algoritmos II

Arvores B
Complexidade da Remo cao
Agora, o n o pai e que possui t 2 chaves repetindo a situa cao
anterior. Ou seja a opera cao propaga-se num determinado
subconjunto de paginas ate chagar `a raiz
Como os merge copiam t 1 elementos a cada nvel da arvore
teremos uma complexidade de O((t 1) log
t
(n)) para os
merge onde log
t
(n) e a altura da arvore
Dessa maneira a complexidade da remo cao e dada por:
O(t log
t
(n)) + O((t 1) log
t
(n)) = O(t log
t
(n))
MO637 Complexidade de Algoritmos II

Arvores B
Endere co das Anima coes
MO637 Complexidade de Algoritmos II

Arvores B
Endere co das Anima coes
Vivio B-Tree (necessita do plug-in vivio):
https://www.cs.tcd.ie/Jeremy.Jones/vivio/trees/B-tree.htm
Busca no Google: vivio b tree animation
MO637 Complexidade de Algoritmos II

Arvores B
Endere co das Anima coes
Vivio B-Tree (necessita do plug-in vivio):
https://www.cs.tcd.ie/Jeremy.Jones/vivio/trees/B-tree.htm
Busca no Google: vivio b tree animation
slady: Java B-Tree applet animation
http://slady.net/java/bt/view.php
Busca no Google: b tree animation java
MO637 Complexidade de Algoritmos II

Arvores B

Você também pode gostar