EAD Árvore árvore binária



Documentos relacionados
1. Introdução Definição Conceitos relacionados... 2

EAD Árvore - representação usando listas ligadas

ALGORITMOS E ESTRUTURAS DE DADOS CES-11 CES-11 CES-11

ESTRUTURAS DE DADOS II MSc. Daniele Carvalho Oliveira

INF1007: Programação 2 10 Árvores Binárias. (c) Dept. Informática - PUC-Rio 1

Linguagem C: Árvores Binarias

Árvores Binárias de Busca

Árvores. Algoritmos e Estruturas de Dados 2005/2006

Árvore Binária de Busca

INF 1007 Programação II

Métodos Computacionais. Árvores

Estruturas de Dados. Prof. Gustavo Willam Pereira Créditos: Profa. Juliana Pinheiro Campos

PROGRAMAÇÃO II 4. ÁRVORE

INF PROGRAMAÇÃO II LISTA DE EXERCÍCIOS 15

2ª Lista de Exercícios

Busca. Pesquisa sequencial

Estruturas de Dados I

Árvores Binárias de Busca

Pesquisa em Memória Primária. Prof. Jonas Potros

Árvores Binárias. Observação: Material elaborado a partir do material do Professor Marcos Costa.

BUSCA EM LISTAS LISTAS SEQÜENCIAIS, LISTAS SIMPLESMENTE E DUPLAMENTE ENCADEADAS E LISTAS CIRCULARES

Listas Duplamente Encadeadas

Árvores binárias de pesquisa com balanceamento. Algoritmos e Estruturas de Dados II

Algoritmos e Estruturas de Dados: Árvore Binária

ESTRUTURAS DE DADOS I. Notas de Aula. Prof. Dr. Gilberto Nakamiti

- UNIVERSIDADE DO VALE DO RIO DOS SINOS CIÊNCIAS EXATAS E TECNOLÓGICAS Curso: Informática / Ciência da Computação

Figura 13.1: Um exemplo de árvore de diretório.

Algoritmos e Estruturas de Dados 2

Estruturas de Dados Árvores

Árvores Balanceadas. Árvore binária completamente balanceada. Ocorre quando a árvore está cheia ou quase cheia com o nível n-1 completo

Árvores Binárias - continuação

Algoritmos e Estrutura de Dados III. Árvores

DAS5102 Fundamentos da Estrutura da Informação

ESTRUTURA DE DADOS DCC013

Estruturas de Dados Aula 15: Árvores 17/05/2011

Pesquisa Sequencial e Binária

Pesquisa em Memória Primária. Algoritmos e Estruturas de Dados II

Filas COMANDOS EM C++ PARA IMPLEMENTAÇÃO DE UMA FILA. Biblioteca padrão <queue>

Pedro Vasconcelos DCC/FCUP. Programação Funcional 15 a Aula Árvores de pesquisa

EAD Fila. - algumas operações realizam-se na frente/cabeça e outras na cauda da Fila

Árvores e Árvores Binárias

Estruturas de Dados. Árvores AVL. Cesar Tadeu Pozzer. Curso de Ciência da Computação UFSM (12/12/2007)

Índice. Capítulo 2 Estrutura de Dados sequencial com armazenamento sequencial

Pesquisa em Memória Primária. Prof. Jonas Potros

Busca em Memória. Secundária

Algoritmos e Estrutura de Dados. Prof. Tiago A. E. Ferreira

Árvores Binárias e Busca. Jeane Melo

struct arv { char info; struct arv* esq; struct arv* dir; };

PROGRAMAÇÃO II 3. PILHA DINÂMICA

Árvores AVL. Prof. Othon M. N. Batista Estrutura de Dados

DAS5102 Fundamentos da Estrutura da Informação

FACULDADE CAMPO LIMPO PAULISTA MESTRADO EM CIÊNCIA DA COMPUTAÇÃO. Projeto e Análise de Algoritmos II Lista de Exercícios 2

INF 1010 Estruturas de Dados Avançadas

Árvore B UNITINS ANÁLISE E DESENVOLVIMENTO DE SISTEMAS 3º PERÍODO 43

ÁRVORES BINÁRIAS DE PESQUISA

Árvore Binária de Busca. Algoritmos e Estrutura de Dados II. Operações Busca e Sucessor. Árvore Binária de Busca. Árvores Rubro-Negras

Universidade Federal de Mato Grosso Estrutura de Dados II

Prof. Yandre Maldonado - 1 PONTEIROS. Prof. Yandre Maldonado e Gomes da Costa

- UNIVERSIDADE DO VALE DO RIO DOS SINOS CIÊNCIAS EXATAS E TECNOLÓGICAS Curso: Informática / Ciência da Computação

{ fazer Pós-Ordem sem recursividade. Poderá cair na prova!!! }

- UNIVERSIDADE DO VALE DO RIO DOS SINOS CENTRO DE CIÊNCIAS EXATAS E TECNOLÓGICAS (C6/6) Curso: Informática

Árvores Binárias Balanceadas

BC1424 Algoritmos e Estruturas de Dados I. Aula 16: Árvores (introdução) Prof. Jesús P. Mena-Chalco. jesus.mena@ufabc.edu.br

CT-234. Análise de Algoritmos e Complexidade Estrutural. Carlos Alberto Alonso Sanches

Árvores & Árvores Binárias

Trabalho 3: Agenda de Tarefas

Métodos Computacionais. Fila

Algoritmos e Estruturas de Dados: Árvore Binária de Busca

Árvores Binárias de Pesquisa. Programação II Prof. Mateus Raeder. Árvores Binárias de Pesquisa. Árvores Binárias de Pesquisa. Classe Nodo Binário

Algoritmos e Estruturas de Dados

Estrutura de Dados Árvores. Prof. Robinson Alves

Pesquisa digital. Algoritmos e Estruturas de Dados II

Métodos de Pesquisa em Memória Primária

Aula 14 Listas Duplamente Encadeadas. prof Leticia Winkler

ÁRVORES ABB (ÁRVORES BINÁRIAS DE BUSCAS) Sérgio Carlos Portari Júnior

Programas operam sobre dados. Dados são relacionados e possuem estrutura. Como representar e manipular dados em um computador

10. Listas Encadeadas

PROGRAMAÇÃO II 3. FILA DINÂMICA

DAS5102 Fundamentos da Estrutura da Informação

DAINF - Departamento de Informática

Complexidade de Algoritmos

Pesquisa Digital. Árvorie. Árvorie. Árvorie. Árvorie. Árvorie: : Estrutura

Árvores. David Menotti Algoritmos e Estruturas de Dados II DInf UFPR

Árvores & Árvores Binárias

Aula T20 BCC202 Pesquisa (Parte 2) Árvores de Pesquisa. Túlio Toffolo

Árvores binárias de busca

AED 2002/2003 p.1/21. Estrutura de dados elementar Métodos de travessia de árvores Procura em árvores binárias. Exemplos de clientes

Algoritmos e Estrutura de Dados. Aula 13 Estrutura de Dados: Árvores de Pesquisa Binária Prof. Tiago A. E. Ferreira

Filas: conceitos e implementações

Aula T13 BCC202 Árvores. Túlio Toffolo

Árvores binárias de busca

Estrutura de Dados. Carlos Eduardo Batista. Centro de Informática - UFPB

ESTRUTURAS DE DADOS AVANÇADAS (INF 1010) (a) Seja um TAD definido por uma lista circular implementada em um vetor.

Geração de código intermediário. Novembro 2006

Árvores Binária de Busca. Prof. César Melo DCC/ICE/UFAM

Estruturas de Dados. Parte dos slides a seguir são adaptações, extensões e traduções para C dos originais:

ESTRUTURA DE DADOS E ALGORITMOS. Árvores Binárias de Busca. Cristina Boeres

Transcrição:

EAD Árvore árvore binária - Uma árvore binária é um conjunto finito de elementos (nodos) que pode ser vazio ou particionado em três subconjuntos: - raiz da árvore (elemento inicial, que é único); - subárvore esquerda (se vista isoladamente forma uma outra árvore); - subárvore direita (se vista isoladamente forma uma outra árvore). - Como a definição de árvore é recursiva, muitas operações sobre árvores binárias são definidas de forma recursiva. - As árvores onde cada nodo, que não seja folha, tem subárvores esquerda e direita não vazias são conhecidas como árvores estritamente binárias. - Uma árvore estritamente binária com n folhas tem 2n-1 nodos.

EAD Árvore árvore binária - o nodo A é a raiz da árvore, - a subárvore esquerda é tem como raiz o nodo B, - a direita é representada pelo nodo C, - uma folha são os casos dos nodos D, G, H e I, - A é pai de B e que B é filho de A, - Os nodos que se encontram no mesmo nível denominam-se de irmãos. - B e C são filhos de A. - B e C são irmãos. D e E são irmãos. H e I são irmãos. - T A é a subárvore enraizada em A, portanto toda a árvore. - T F é a subárvore enraizada em F, que contém os nós F, H e I. - Os graus de saída do nodo B é 2 e do nodo C é 1. - O nodo A tem nível 0; os nodos B e C têm nível 1; os nodos D, E e F têm nível 2; os nodos G, H e I têm nível 3. - A altura de A é 4, a altura de C é 3 enquanto que a altura de E e F é 2.

EAD Árvore árvore binária - Um caminho da árvore - é composto por uma sequência de nodos consecutivos (n1, n2, n3,,nk-1, nk) tal que existe sempre a relação: nj é pai de nj+1; - os k nodos formam um caminho de comprimento k-1. - O comprimento entre o nodo A e o nodo H é 3 (figura anterior). - A altura de um nodo pode também ser definida como o comprimento do maior caminho deste nodo até alguns de seus descendentes. - Descendentes de um nodo são todos os nodos que podem ser alcançados caminhando-se para baixo a partir daquele nodo. - A altura de cada uma das folhas é 1.

EAD Árvore árvore binária - Uma árvore completa é - uma árvore estritamente binária na qual todas as folhas estão no mesmo nível k - Sendo k a profundidade da árvore, - o número total de nodos é 2k+1-1 e - o número total de folhas é 2k. - Embora uma árvore binária completa possua muitos nodos (o máximo para cada profundidade), a distância da raiz a uma folha qualquer é relativamente pequena.

EAD Árvore árvore binária - A figura - representa uma árvore completa de nível 3; - tem profundidade 3 com 15 nodos (24-1) e 8 folhas (23).

- Cada nodo de uma árvore binária pode ser representado por uma estrutura contendo - a informação e - as ligações a outros nodo (que correspondem à raiz das subárvores esquerda e direita). - Por exemplo, a declaração seguinte: struct NodoArv { Info Elemento; Elemento struct NodoArv *Esquerda; *Esquerda *Direita struct NodoArv *Direita; }; typedef struct NodoArv *PNodoArv;

3.6. Copiar uma árvore

3.7. Verificar a igualdade entre (duas) árvores Entrada: ponteiros para as duas raízes das árvores que se pretendem comparar Saída: 1 (se iguais); 0 (se diferentes)

3.9. Determinar a altura de uma árvore

3.10. Listar os elementos de uma árvore Travessia em pré-ordem: raíz, subárvore esquerda e subárvore direita. Travessia em em-ordem: subárvore esquerda, raíz e subárvore direita. Travessia em pós-ordem: subárvore esquerda, subárvore direita e raíz.

3.10. Listar os elementos de uma árvore Travessia em pré-ordem: raíz, subárvore esquerda e subárvore direita. Entrada: ponteiro para a raíz duma árvore Saída: nada (mostra os elementos da árvores seguidos)

3.10. Listar os elementos de uma árvore Travessia em em-ordem: subárvore esquerda, raíz e subárvore direita. Entrada: ponteiro para a raíz duma árvore Saída: nada (mostra os elementos da árvores seguidos)

3.10. Listar os elementos de uma árvore Travessia em pós-ordem: subárvore esquerda, subárvore direita e raíz. Entrada: ponteiro para a raíz duma árvore Saída: nada (mostra os elementos da árvores seguidos)

3.11. Pesquisar um elemento numa árvore Entrada: ponteiro para a raíz duma árvore e o elemento a procurar Saída: 1 (o elemento existe na árvore); 0 (o elemento não existe na árvore)

3.12. Inserir um elemento numa árvore O algoritmo de inserção de um elemento numa árvore binária: - começa com uma pesquisa deste elemento na árvore (posição de inserção), - o nodo com o novo elemento é sempre inserido como folha da árvore. Necessidade da pesquisa obedecer a algum critério - para existir uniformidade na distribuição dos nodos pela árvore - de forma a que árvore não fique totalmente desequilibrada.

3.12. Inserir um elemento numa árvore Um critério possível pode ser a altura das subárvores de cada nodo.

3.13. Remover um elemento de uma árvore Considerar três casos distintos, segundo as caracteristicas do nodo a remover: - se é uma folha, - se é um nodo com um único filho, ou - se é um nodo com dois filhos.

3.13. Remover um elemento de uma árvore Remoção de uma folha

3.13. Remover um elemento de uma árvore Remoção de um nodo com um único filho

3.13. Remover um elemento de uma árvore Remoção de um nodo com dois filhos O processo implica substituir este nodo por uma das folhas sua descendente: 1º escolher uma das folhas descendente do nodo a remover que o irá substituir; 2º substituir o elemento do nodo a ser removido pelo elemento da folha escolhida; 3º remover a folha escolhida.

3.13. Remover um elemento de uma árvore - Implementação Entrada: ponteiro para a raíz duma árvore e o elemento a remover (que existe na árvore) Saída: ponteiro para a raíz da árvore (que pode ter sofrido alteração)

3.13. Remover um elemento de uma árvore Implementação Possível função para remover um nodo de uma árvore binária: Entrada: ponteiro para o nodo que se pretende excluir (raíz de subárvore não vazia) Saída: ponteiro para a raíz da subárvore sem um elemento (pode ter sido alterada) PNodoArv RemoverNodo (PNodoArv T) { PNodoArv R; Info X; if (T Esquerda == NULL && T Direita == NULL) { // T é uma folha T = LibertarNodo(T); return T; } if (T Esquerda == NULL) { // só um filho direito R = T; T = T Direita; R = LibertarNodo(R); return T; }

} if (T Direita == NULL) { // só um filho esquerdo R = T; T = T Esquerda; R = LibertarNodo(R); return T; } // 2 filhos: remover a folha escolhida e copiar a sua informação P = ProcurarFolha(T, &X); P = LibertarNodo(P); T Elemento = X; return T;

3.13. Remover um elemento de uma árvore Implementação Possível função recursiva para procurar uma folha descendente do nodo a ser removido: PNodoArv ProcurarFolha (PNodoArv T, Info *X) { PNodoArv P; if (T Esquerda == NULL && T Direita == NULL) { *X = T Elemento; return T; } if (Altura(T Esquerda) > Altura(T Direita)) return ProcurarFolha(T Esquerda, X); else return ProcurarFolha(T Direita, X); }

3.14. Travessias não recursivos - Necessário utilizar uma memória para guardar os nodos já visitados e/ou por visitar, de forma a poder-se regressar posteriormente a estes nodos. - Como o caminho de regresso é normalmente o caminho percorrido no sentido contrário, devemos usar uma EAD Pilha ou uma EAD Fila para tal. - Nas travessia mais comuns, como as em pré-ordem, em-ordem e pós-ordem - utiliza-se uma EAD Pilha para armazenar os nodos já visitados. - definição da EAD Pilha necessária: struct Pilha { PNodoArv Elemento; struct Pilha *Ant; }

3.14. Travessias não recursivos void ListarPreOrdem (PNodoArv T) { struct Pilha S; PNodoArv P; if (ArvoreVazia(T)) return; S = Criar(); if (S == NULL) return; S = Push(S, T); while (!Vazia(S)) { P = Topo(S); S = Pop(S); printf(p Elemento); if (P Direita!= NULL) S = Push(S, P Direita); if (P Esquerda!= NULL) S = Push(S, P Esquerda); } }

3.14. Travessias não recursivos - Como se pode verificar, as versões recursivas dos algoritmos de travessias estudadas são muito mais fáceis de implementar do que as correspondentes versões iterativas. - No entanto, num outro tipo de travessia isso não acontece, como é o caso da travessia por níveis, na qual se utiliza uma EAD Fila (e não uma EAD Pilha). - Uma função iterativa para este tipo de travessia, assim como a EAD Fila. struct Fila { PNodoArv Elemento; struct Fila *Prox; }

3.14. Travessias não recursivos void ListarPorNiveis (PNodoArv T) { struct Fila Q; PNodoArv P; if (ArvoreVazia(T)) return; Q = Criar(); if (Q == NULL) return; Q = Juntar(Q, T); while (!Vazia(Q)) { P = Frente(Q); printf(p Elemento); Q = Remover(Q); if (P Direita!= NULL) Q = Juntar(Q, P Esquerda); if (P Esquerda!= NULL) Q = Juntar(Q, P Direita); } }