Professional Documents
Culture Documents
rvore binria
Aula prtica 1
E como manipul-las?
A palavra-chave : Recurso.
E porque recurso?
A recurso usa um mtodo que ser estudado mais a frente no curso,
chamado dividir para conquistar, basicamente dividindo o problema em
subproblemas menores.
OBS: H como fazer de
modo iterativo.
Falando em complexidade
Veremos a partir de agora alguns algoritmos usados em rvores binrias.
Insero
Remoo
Encaminhamento
a) In Ordem
b) Pr Ordem
c) Ps Ordem
Complexidade: O(log n) ou O(h)*
Obs: O(h) caso a rvore esteja
degenerada (Veremos frente)
Insero
A insero feita somente nas folhas.
O algoritmo deve chegar a folha onde deve ser adicionada (lembrando de
respeitar a propriedade da rvore binria).
Elementos que j pertencem
a rvore, no devem ser
adicionados novamente.
Encaminhamento
a) In Ordem:
N Esquerdo Raiz N
Direito
b) Pr Ordem:
Raiz N Esquerdo N
Direito
c) Ps Ordem:
N Esquerdo Raiz N
Direito
Obs: Lembrem se de pensar
recursivamente e como cada
algoritmo executado a cada iterao
desse tipo de recurso.
Remoo
Uma remoo em rvores Binrias um pouco mais complexo do que a insero
e o encaminhamento.
Essa complexidade se d pelo fato que pode-se remover ns em qualquer
posio da rvore, mas a deve-se manter ao mximo a propriedade de rvores
binrias.
Uma rvore binria que perde sua propriedade (ou seja, vira uma lista
encadeada) chamada degenerada.
Para contornar esse problema, foi implementada a rvore do Tipo AVL, mas esse
assunto vir na prxima aula.
Em uma remoo, considera-se 3 tipos:
a) N no tem filhos. (Folha)
b) N tem somente um filho.
c) N tem 2 filhos.
Remoo
a) N sem filhos (Folha): Quando no h filhos, desaloca-se o n em questo e o
ponteiro do pai (que aponta para o filho a ser removido), deve tornar-se NULL.
Remoo
b) N com 1 filho: O pai desalocado e o filho se torna o novo pai.
Remoo
c) N com 2 filhos: Para a remoo de um n com 2 filhos preciso conhecer um
conceito bsico, o sucessor.
O sucessor de um elemento cujo n tem um filho direita o elemento que est
um passo direita e tantos passos esquerda quanto for necessrio.
A regra anloga esquerda.
Remoo
Remoo
Remoo