Algoritmos e Estruturas de Dados: Árvore Binária de Busca
|
|
|
- Maria de Fátima Maranhão Farinha
- 10 Há anos
- Visualizações:
Transcrição
1 Busca pelo nodo 72 Árvore Binária de Busca Introdução 2/21 Algoritmos e Estruturas de Dados: Árvore Binária de Busca 44 Raiz Rômulo Silva de Oliveira Departamento de Automação e Sistemas DAS UFSC [email protected] Maio/ Folha Folha Folha Folha Folha Folha Folha 4 Mastering Algorithms with C Kyle Loudon O Reilly, 1999 Livros de algoritmos e estruturas de dados em geral Referências Árvore Binária de Busca Introdução 3/21 Árvores binárias de busca são estruturas eficientes para pesquisa No pior caso percorre apenas um galho O(lg N) N é o número de nodos na árvore Desde que a árvore esteja balanceada Caso a árvore esteja completamente desbalanceada: Como uma lista encadeada O(N) 2 5 Árvore binária organizada para pesquisa Pesquisa por um nodo inicia na raiz Árvore Binária de Busca Introdução 1/21 Desce nível por nível até encontrar o nodo buscado Quando encontra um nodo maior que o buscado, segue o pointer da esquerda Quando encontra um nodo menor que o buscado, segue o pointer da direita Caso chegue em uma folha, ele não existe na árvore Árvores AVL Adel son-vel skii e Landis, 1962 Árvore binária Árvore Binária de Busca Introdução 4/21 Cada nodo possui um fator de balanceamento O fator de balanceamento de um nodo é a altura da sub-árvore cuja raiz é o seu filho esquerdo menos a altura da sub-árvore cuja raiz é o seu filho direito 3 6
2 Árvore Binária de Busca Introdução 5/21 Árvore AVL exige que todos os fatores de balanceamento sejam +1,0,-1 Quando nodos são inseridos a árvore precisa ser ajustada +1 é pesada a esquerda -1 é pesada a direita 0 é balanceada Árvore Binária de Busca Introdução 8/21 Rotação Left-Left X é o elemento recem inserido A é o ancestral mais próximo de X com fator de balançeamento ±2 X está na sub-árvore esquerda da sub-árvore esquerda de A Pivo é o filho a esquerda de A Ações: A.esquerda Pivo.direita Pivo.direita A Quem apontava A agora aponta Pivo Fator de balançeamento de A e Pivo fica Árvore Binária de Busca Introdução 6/21 Inserção e pesquisa na árvore AVL é semelhante à árvore binária comum Rotação Left-Left Árvore Binária de Busca Introdução 9/21 Após a inserção é necessário Contabilizar as mudanças nos fatores de balanceamento Se algum fator de balanceamento terminar +2 ou -2 é necessário rebalançear a árvore deste ponto para baixo Rebalançeamento é feito com operações de rotação 8 11 Árvore Binária de Busca Introdução 7/21 Uma rotação rebalanceia parte de uma árvore AVL A rotação reposiciona nodos enquanto preserva a rela ção sub-árvore esquerda < pai < sub-árvore direita Após a rotação: Os fatores de balanceamento de todos os nodos na sub- árvore rotacionada são novamente -1, 0 ou +1 Árvore Binária de Busca Introdução 10/21 Rotação Right-Right X é o elemento recem inserido A é o ancestral mais próximo de X com fator de balançeamento ±2 X está na sub-árvore direita da sub-árvore direita de A Simétrico à rotação Left-Left 4 tipos de rotação: Left-left LL Left-Right LR Right-Right RR Right-Left RL 9 12
3 Árvore Binária de Busca Introdução 11/21 X é o elemento recem inserido A é o ancestral mais próximo de X com fator de balançeamento ±2 X está na sub-árvore direita da sub-árvore esquerda de A Pivo é o filho esquerdo de A Neto é o filho direito de Pivo Ações: Pivo.direita Neto.esquerda Neto.esquerda Pivo A.esquerda Neto.direita Neto.direita A Quem apontava A agora aponta Neto Árvore Binária de Busca Introdução 14/21 Ajuste do fator de balanceamento depende do caso Fator de balanceamento do Neto era +1 A fica -1 Pivo fica Árvore Binária de Busca Introdução 12/21 Árvore Binária de Busca Introdução 15/21 Ajuste do fator de balanceamento depende do caso Fator de balanceamento do Neto era 0 A fica 0 Pivo fica Árvore Binária de Busca Introdução 13/21 Ajuste do fator de balanceamento A e Pivo depende do caso Neto fica 0 Demais não mudam Árvore Binária de Busca Introdução 16/21 Ajuste do fator de balanceamento depende do caso Fator de balanceamento do Neto era 1 A fica 0 Pivo fica
4 Árvore Binária de Busca Introdução 17/21 Rotação Right-Left X é o elemento recem inserido A é o ancestral mais próximo de X com fator de balançeamento ±2 X está na sub-árvore esquerda da sub-árvore direita de A Pivo é o filho direito de A Neto é o filho esquerdo de Pivo Exemplo inserção Rotação LR é necessária Árvore Binária de Busca Introdução 20/21 Simétrico à rotação Left-Right Exemplo inserção Rotação RL é necessária Árvore Binária de Busca Introdução 18/21 Remoção pode ser completa Requer rebalanceamento da árvore Árvore Binária de Busca Introdução 21/21 Remoção pode ser preguiçosa Nodo é marcado como escondido mas não é realmente removido O campo hidden da estrutura AvlNode recebe 1 Se o dado for inserido novamente, apenas torna o nodo vis ível Remoção preguiçosa é aceitável se o número de nodos removidos for pequeno com relação ao número de nodos inseridos Se muitos nodos serão removidos, melhor fazer uma remoção completa e ajustar a árvore Exemplo inserção Rotação LL é necessária Árvore Binária de Busca Introdução 19/21 Árvore Binária de Busca Interface 1/6 bistree_init void bistree_init(bistree *tree, void (*compare)(const void *key1, const void *key2), void (*destroy)(void *data)); Nenhum. Inicializa a árvore binária de busca especificada por tree. Esta operação deve ser chamada para uma árvore binária de busca antes que a árvore possa ser usada com qualquer outra operação. O pointer para função compare especifica uma função definida pelo usuário para comparar elementos. Esta função deve retornar 1 se key1>key2, 0 se key1=key2, e -1 se key1<key2. O argumento destroy prove uma maneira para liberar dados dinamicamente alocados quando bistree_destroy for chamada. Ele funciona de maneira similar àquela descrita para bitree_destroy. Para uma árvore binária de busca contendo dados que não devem ser liberados, destroy deve ser NULL
5 bistree_destroy void bistree_destroy(bistree *tree); Árvore Binária de Busca Interface 2/6 Nenhum. Destrói a árvore binária de busca especificada por tree. Nenhuma outra operação é permitida após a chamada de bistree_destroy a não ser que bistree_init seja chamada novamente. A operação bistree_destroy remove todos os nodos da árvore binária de busca e chama a função passada como destroy para bistree_init uma vez para cada nodo a medida que eles são removidos, desde que destroy não seja NULL. bistree_lookup int bistree_lookup(const BisTree *tree, void **data); Árvore Binária de Busca Interface 5/6 0 se o dado é encontrado na árvore binária de busca, ou -1 caso contrário. Determina se um nodo confere com data na árvore binária de busca especificada como tree. Se um nodo é encontrado, data aponta para o dado encontrado na árvore binária de busca após o retorno bistree_insert int bistree_insert(bistree *tree, const void *data); Árvore Binária de Busca Interface 3/6 0 se a inserção do nodo tiver sucesso, 1 se o nodo já está na árvore, ou -1 caso contrário. Insere um nodo na árvore binária de busca especificada por tree. O novo nodo contem um pointer para data, assim a memória referenciada por data deve permanecer válida pelo tempo que o nodo permanecer na árvore binária de busca. É responsabilidade do chamador gerenciar a mem ória associada com data. bistree_size int bistree_size(const BisTree *tree); Número de nodos na árvore. Árvore Binária de Busca Interface 6/6 Macro que avalia o número de nodos na árvore binária de busca especificada por tree bistree_remove int bistree_remove(bistree *tree, const void *data); Árvore Binária de Busca Interface 4/6 0 se a remoção do nodo teve sucesso, ou -1 caso contr ário. Remove o nodo que confere com data da árvore binária de busca especificada por tree. Na realidade, esta operação apenas realiza uma remoção preguiçosa, na qual o nodo é simplesmente marcado como escondido. Logo, nenhum pointer para os dados que conferem com data é retornado. Além disto, os dados na árvore devem permanecer válidos mesmo após terem sido removidos. Consequentemente, o tamanho da árvore binária de busca, como retornado por bistree_size, não decresce após a remoção de um nodo. #ifndef BISTREE_H #define BISTREE_H #include "bitree.h" #define AVL_LFT_HEAVY 1 #define AVL_BALANCED 0 #define AVL_RGT_HEAVY -1 typedef struct AvlNode_ { void int int AvlNode; *data; hidden; factor; Árvore Binária de Busca Header 1/2 typedef BiTree BisTree; 27 30
6 void bistree_init(bistree *tree, int (*compare)(const void *key1, const void *key2), void (*destroy)(void *data)); Árvore Binária de Busca Header 2/2 Árvore Binária de Busca Implementação 3/24 // Perform an LR rotation void bistree_destroy(bistree *tree); int bistree_insert(bistree *tree, const void *data); int bistree_remove(bistree *tree, const void *data); int bistree_lookup(bistree *tree, void **data); grandchild = bitree_right(left); bitree_right(left) = bitree_left(grandchild); bitree_left(grandchild) = left; bitree_left(*node) = bitree_right(grandchild); bitree_right(grandchild) = *node; #define bistree_size(tree) ((tree)->size) #endif #include <stdlib.h> #include <string.h> #include "bistree.h" Árvore Binária de Busca Implementação 1/24 static void destroy_right(bistree *tree, BiTreeNode *node); 32 Árvore Binária de Busca Implementação 4/24 switch (((AvlNode *)bitree_data(grandchild))->factor) { case AVL_LFT_HEAVY: ((AvlNode *)bitree_data(*node))->factor = AVL_RGT_HEAVY; ((AvlNode *)bitree_data(left))->factor = AVL_BALANCED; case AVL_BALANCED: ((AvlNode *)bitree_data(left))->factor = AVL_BALANCED; case AVL_RGT_HEAVY: ((AvlNode *)bitree_data(left))->factor = AVL_LFT_HEAVY; ((AvlNode *)bitree_data(grandchild))->factor = AVL_BALANCED; *node = grandchild; 35 Árvore Binária de Busca Implementação 2/24 static void rotate_left(bitreenode **node) { Árvore Binária de Busca Implementação 5/24 static void rotate_right(bitreenode **node) { BiTreeNode *left, *grandchild; BiTreeNode *right, *grandchild; left = bitree_left(*node); if (((AvlNode *)bitree_data(left))->factor == AVL_LFT_HEAVY) { right = bitree_right(*node); if (((AvlNode *)bitree_data(right))->factor == AVL_RGT_HEAVY) { // Perform an LL rotation bitree_left(*node) = bitree_right(left); bitree_right(left) = *node; ((AvlNode *)bitree_data(left))->factor = AVL_BALANCED; *node = left; // Perform an RR rotation bitree_right(*node) = bitree_left(right); bitree_left(right) = *node; ((AvlNode *)bitree_data(right))->factor = AVL_BALANCED; *node = right; 33 36
7 Árvore Binária de Busca Implementação 6/24 // Perform an RL rotation grandchild = bitree_left(right); bitree_left(right) = bitree_right(grandchild); bitree_right(grandchild) = right; bitree_right(*node) = bitree_left(grandchild); bitree_left(grandchild) = *node; 37 Árvore Binária de Busca Implementação 9/24 static void destroy_right(bistree *tree, BiTreeNode *node) { BiTreeNode **position; if (bitree_size(tree) == 0) if (node == NULL) position = &tree->root; else position = &node->right; if (*position!= NULL) { destroy_left(tree, *position); destroy_right(tree, *position); if (tree->destroy!= NULL) tree->destroy(((avlnode *)(*position)->data)->data); free((*position)->data); free(*position); *position = NULL; tree->size--; 40 Árvore Binária de Busca Implementação 7/24 switch (((AvlNode *)bitree_data(grandchild))->factor) { case AVL_LFT_HEAVY: ((AvlNode *)bitree_data(right))->factor = AVL_RGT_HEAVY; case AVL_BALANCED: ((AvlNode *)bitree_data(right))->factor = AVL_BALANCED; case AVL_RGT_HEAVY: ((AvlNode *)bitree_data(*node))->factor = AVL_LFT_HEAVY; ((AvlNode *)bitree_data(right))->factor = AVL_BALANCED; ((AvlNode *)bitree_data(grandchild))->factor = AVL_BALANCED; *node = grandchild; 38 Árvore Binária de Busca Implementação 10/24 static int insert(bistree *tree, BiTreeNode **node, const void *data, int *balanced) { AvlNode int *avl_data; cmpval, retval; if (bitree_is_eob(*node)) { // Handle insertion into an empty tree if ((avl_data = (AvlNode *)malloc(sizeof(avlnode))) == NULL) avl_data->factor = AVL_BALANCED; avl_data->hidden = 0; avl_data->data = (void *)data; return bitree_ins_left(tree, *node, avl_data); 41 Árvore Binária de Busca Implementação 8/24 static void destroy_left(bistree *tree, BiTreeNode *node) { BiTreeNode **position; if (bitree_size(tree) == 0) if (node == NULL) position = &tree->root; else position = &node->left; if (*position!= NULL) { destroy_left(tree, *position); destroy_right(tree, *position); if (tree->destroy!= NULL) tree->destroy(((avlnode *)(*position)->data)->data); free((*position)->data); free(*position); *position = NULL; tree->size--; 39 Árvore Binária de Busca Implementação 11/24 // Handle insertion into a tree that is not empty cmpval = tree->compare(data, ((AvlNode *)bitree_data(*node))->data); if (cmpval < 0) { // Move to the left if (bitree_is_eob(bitree_left(*node))) { if ((avl_data = (AvlNode *)malloc(sizeof(avlnode))) == NULL) avl_data->factor = AVL_BALANCED; avl_data->hidden = 0; avl_data->data = (void *)data; if (bitree_ins_left(tree, *node, avl_data)!= 0) *balanced = 0; if ((retval = insert(tree, &bitree_left(*node), data, balanced))!= 0) { return retval; 42
8 Árvore Binária de Busca Implementação 12/24 // Ensure that the tree remains balanced if (!(*balanced)) { switch (((AvlNode *)bitree_data(*node))->factor) { case AVL_LFT_HEAVY: rotate_left(node); *balanced = 1; case AVL_BALANCED: ((AvlNode *)bitree_data(*node))->factor = AVL_LFT_HEAVY; case AVL_RGT_HEAVY: *balanced = 1; Árvore Binária de Busca Implementação 15/24 // Handle finding a copy of the data if (!((AvlNode *)bitree_data(*node))->hidden) { // Do nothing since the data is in the tree and not hidden return 1; /* if (cmpval < 0) */ Árvore Binária de Busca Implementação 13/24 else if (cmpval > 0) { // Move to the right if (bitree_is_eob(bitree_right(*node))) { if ((avl_data = (AvlNode *)malloc(sizeof(avlnode))) == NULL) avl_data->factor = AVL_BALANCED; avl_data->hidden = 0; avl_data->data = (void *)data; Árvore Binária de Busca Implementação 16/24 // Insert the new data and mark it as not hidden if (tree->destroy!= NULL) { tree->destroy(((avlnode *)bitree_data(*node))->data); ((AvlNode *)bitree_data(*node))->data = (void *)data; ((AvlNode *)bitree_data(*node))->hidden = 0; *balanced = 1; if (bitree_ins_right(tree, *node, avl_data)!= 0) *balanced = 0; if ((retval = insert(tree, &bitree_right(*node), data, balanced))!= 0) { return retval; return 0; Árvore Binária de Busca Implementação 14/24 // Ensure that the tree remains balanced if (!(*balanced)) { switch (((AvlNode *)bitree_data(*node))->factor) { case AVL_LFT_HEAVY: ((AvlNode *)bitree_data(*node))->factor = AVL_BALANCED; *balanced = 1; case AVL_BALANCED: ((AvlNode *)bitree_data(*node))->factor = AVL_RGT_HEAVY; case AVL_RGT_HEAVY: rotate_right(node); *balanced = 1; /* if (cmpval > 0) */ 45 Árvore Binária de Busca Implementação 17/24 static int hide(bistree *tree, BiTreeNode *node, const void *data) { int cmpval, retval; if (bitree_is_eob(node)) cmpval = tree->compare(data, ((AvlNode *)bitree_data(node))->data); if (cmpval < 0) // Move to the left retval = hide(tree, bitree_left(node), data); else if (cmpval > 0) // Move to the right retval = hide(tree, bitree_right(node), data); // Mark the node as hidden ((AvlNode *)bitree_data(node))->hidden = 1; retval = 0; return retval; 48
9 Árvore Binária de Busca Implementação 18/24 static int lookup(bistree *tree, BiTreeNode *node, void **data) { int cmpval, retval; if (bitree_is_eob(node)) { // Return that the data was not found Árvore Binária de Busca Implementação 21/24 void bistree_destroy(bistree *tree) { destroy_left(tree, NULL); memset(tree, 0, sizeof(bistree)); cmpval = tree->compare(*data, ((AvlNode *)bitree_data(node))->data); if (cmpval < 0) { // Move to the left retval = lookup(tree, bitree_left(node), data); else if (cmpval > 0) { // Move to the right retval = lookup(tree, bitree_right(node), data); Árvore Binária de Busca Implementação 19/24 if (!((AvlNode *)bitree_data(node))->hidden) { // Pass back the data from the tree *data = ((AvlNode *)bitree_data(node))->data; retval = 0; // Return that the data was not found Árvore Binária de Busca Implementação 22/24 int bistree_insert(bistree *tree, const void *data) { int balanced = 0; return insert(tree, &bitree_root(tree), data, &balanced); return retval; Árvore Binária de Busca Implementação 20/24 void bistree_init(bistree *tree, int (*compare)(const void *key1, const void *key2), void (*destroy)(void *data)) { bitree_init(tree, destroy); tree->compare = compare; Árvore Binária de Busca Implementação 23/24 int bistree_remove(bistree *tree, const void *data) { return hide(tree, bitree_root(tree), data); 51 54
10 Árvore Binária de Busca Implementação 24/24 int bistree_lookup(bistree *tree, void **data) { return lookup(tree, bitree_root(tree), data); 55 Árvore Binária de Busca Sumário Método eficiente para implementar tabelas Esforço mesmo no pior caso é bom Mais complexo que tabela por dispersão Mas o módulo pode ser implementado uma vez e reusado muitas vezes Existem inúmeras variações de árvores de busca Com algumas vantagens e desvantagens pontuais Mas o princípio é sempre o mesmo: Manter a árvore balanceada 56
Algoritmos e Estruturas de Dados: Árvore Binária
Algoritmos e Estruturas de Dados: Árvore Binária Exemplo de árvore binária e são os filhos de Altura desta árvore é 4 é a raiz da sub-árvore esquerda de Rômulo Silva de Oliveira Departamento de Automação
Algoritmos e Estruturas de Dados: Lista Duplamente Encadeada
Lista Duplamente Encadeada Interface 1/13 dlist_init void dlist_init(dlist *list, void (*destroy)(void *data)); Algoritmos e Estruturas de Dados: Lista Duplamente Encadeada Rômulo Silva de Oliveira Departamento
INF1007 - PROGRAMAÇÃO II LISTA DE EXERCÍCIOS 15
INF1007 - PROGRAMAÇÃO II LISTA DE EXERCÍCIOS 15 1. Um número racional é expresso por dois inteiros: um numerador e um denominador (este último diferente de zero!). Implemente um TAD para representar números
Árvores AVL. Prof. Othon M. N. Batista Estrutura de Dados
Árvores AVL Prof. Othon M. N. Batista Estrutura de Dados Roteiro (/2) Árvore Binária de Pesquisa - Pior Tempo ABP Balanceada e Não Balanceada Balanceamento de Árvores Balanceamento de ABP Balanceamento
Algoritmos e Estruturas de Dados: Tabela de Dispersão com Encadeamento
Algoritmos e Estruturas de Dados: Tabela de Dispersão com Encadeamento Rômulo Silva de Oliveira Departamento de Automação e Sistemas DAS UFSC [email protected] http://www.das.ufsc.br/~romulo Maio/011
Mo:vação. Árvore AVL. Caracterís:cas. Origem. Exemplo. Exercício 1 Qual é a altura dos nodos 50 e 44?
Mo:vação Árvore AVL Árvores binárias de Pesquisa possuem uma tendência natural de desbalancear 1 2 Rohit Gheyi [email protected] 6 8 1 2 Origem Adelson Velskii, G.; E. M. Landis (1962). "An algorithm
Busca. Pesquisa sequencial
Busca Banco de dados existem para que, de tempos em tempos, um usuário possa localizar o dado de um registro, simplesmente digitando sua chave. Uma tabela ou um arquivo é um grupo de elementos, cada um
Estruturas de Dados. Prof. Gustavo Willam Pereira Créditos: Profa. Juliana Pinheiro Campos
Estruturas de Dados Prof. Gustavo Willam Pereira Créditos: Profa. Juliana Pinheiro Campos Árvores Conceitos Árvores binárias Árvores binárias de pesquisa Árvores binárias balanceadas Árvores ESTRUTURAS
Estruturas de Dados I
UFES - Curso de verão 2011 Estruturas de Dados I Profa. Juliana Pinheiro Campos [email protected] Árvores binárias de busca (ou São árvores projetadas para dar suporte a operações de busca de forma eficiente.
Árvores Balanceadas. Árvore binária completamente balanceada. Ocorre quando a árvore está cheia ou quase cheia com o nível n-1 completo
Árvores Balanceadas As árvores binárias de pesquisa são, em alguns casos, pouco recomendáveis para as operações básicas (inserção, remoção e busca) Árvores binárias de pesquisa degeneradas tornam as operações
EAD Árvore - representação usando listas ligadas
4.1. Definição É uma árvore binária em que os seus nodos têm associado uma chave, que - determina a sua posição de colocação na árvore e - obedece às seguintes regras: a chave de um nodo é - maior do que
Pesquisa Sequencial e Binária
Pesquisa Sequencial e Binária Prof. Túlio Toffolo http://www.toffolo.com.br BCC202 Aula 20 Algoritmos e Estruturas de Dados I Pesquisa em Memória Primária Introdução - Conceitos Básicos Pesquisa Sequencial
BUSCA EM LISTAS LISTAS SEQÜENCIAIS, LISTAS SIMPLESMENTE E DUPLAMENTE ENCADEADAS E LISTAS CIRCULARES
BUSCA EM LISTAS LISTAS SEQÜENCIAIS, LISTAS SIMPLESMENTE E DUPLAMENTE ENCADEADAS E LISTAS CIRCULARES ALGORITMOS DE BUSCA EM LISTAS COM ALOCAÇÃO SEQÜENCIAL Busca em Listas Lineares A operação de busca é
Árvores Binárias de Busca
Árvores Binárias de Busca Definição Uma Árvore Binária de Busca possui as mesmas propriedades de uma AB, acrescida da seguinte propriedade: Para todo nó da árvore, se seu valor é X, então: Os nós pertencentes
EAD Árvore árvore binária
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
Linguagem C: Árvores Binarias
Instituto de C Linguagem C: Árvores Binarias Luis Martí Instituto de Computação Universidade Federal Fluminense [email protected] - http://lmarti.com Tópicos Principais Introdução Árvores binárias Implementação
Árvores Binárias de Busca
Árvores Binárias de Busca Uma Árvore Binária de Busca T (ABB) ou Árvore Binária de Pesquisa é tal que ou T = 0 e a árvore é dita vazia ou seu nó contém uma chave e: 1. Todas as chaves da sub-árvore esquerda
INF1007: Programação 2 10 Árvores Binárias. (c) Dept. Informática - PUC-Rio 1
INF1007: Programação 2 10 Árvores Binárias (c) Dept. Informática - PUC-Rio 1 Tópicos Principais Introdução Árvores binárias Representação em C Ordens de percurso em árvores binárias Altura de uma árvore
Pesquisa em Memória Primária. Algoritmos e Estruturas de Dados II
Pesquisa em Memória Primária Algoritmos e Estruturas de Dados II Pesquisa em Memória Primária Pesquisa: Recuperação de informação em um grande volume de dados Informação é dividida em registros e cada
Árvore Binária de Busca
Árvore Binária de Busca 319 Árvore Binária de Busca! construída de tal forma que, para cada nó:! nós com chaves menores estão na sub-árvore esquerda! nós com chaves maiores (ou iguais) estão na subárvore
INF 1007 Programação II
INF 1007 Programação II Aula 14 Árvores Binárias Edirlei Soares de Lima Árvores Uma estrutura de dados do tipo árvore permite que dados sejam organizados de maneira hierárquica.
Aula T20 BCC202 Pesquisa (Parte 2) Árvores de Pesquisa. Túlio Toffolo www.decom.ufop.br/toffolo
Aula T20 BCC202 Pesquisa (Parte 2) Árvores de Pesquisa Túlio Toffolo www.decom.ufop.br/toffolo Árvore AVL n Árvore binária de busca tal que, para qualquer nó interno v, a diferença das alturas dos filhos
- UNIVERSIDADE DO VALE DO RIO DOS SINOS CIÊNCIAS EXATAS E TECNOLÓGICAS Curso: Informática / Ciência da Computação
Programação 1I Prof. Osório Árvores Binárias Pag.: 1 - UNIVERSIDADE DO VALE DO RIO DOS SINOS CIÊNCIAS EXATAS E TECNOLÓGICAS Curso: Informática / Ciência da Computação Programação II Disciplina: Linguagem
Estruturas de Dados. Árvores AVL. Cesar Tadeu Pozzer. [email protected], [email protected]. Curso de Ciência da Computação UFSM (12/12/2007)
struturas de ados Árvores VL esar Tadeu Pozzer [email protected], [email protected] urso de iência da omputação UFSM (12/12/2007) Árvore VL Uma árvore binária é denominada VL quando a diferença de altura
Métodos Computacionais. Árvores
Métodos Computacionais Árvores Árvores Vetores e Listas são ótimos para representar estrutura de dados lineares, mas não para modelar dados hierárquicos Exemplos de dados hierárquicos: sistema de arquivos
Árvores Binárias Balanceadas
Árvores Binárias Balanceadas Elisa Maria Pivetta Cantarelli Árvores Balanceadas Uma árvore é dita balanceada quando as suas subárvores à esquerda e à direita possuem a mesma altura. Todos os links vazios
Árvore B UNITINS ANÁLISE E DESENVOLVIMENTO DE SISTEMAS 3º PERÍODO 43
AULA A 3 ESTRUTURA RA DE DADOS Árvore B Esperamos que, ao final desta aula, você seja capaz de: identificar as vantagens da árvore B em relação às árvores binária de busca e AVL; conhecer as funções de
Pesquisa em Memória Primária. Prof. Jonas Potros
Pesquisa em Memória Primária Prof. Jonas Potros Pesquisa em Memoria Primária Estudo de como recuperar informação a partir de uma grande massa de informação previamente armazenada. A informação é dividida
CT-234. Análise de Algoritmos e Complexidade Estrutural. Carlos Alberto Alonso Sanches
CT-234 Estruturas de Dados, Análise de Algoritmos e Complexidade Estrutural Carlos Alberto Alonso Sanches CT-234 4) Árvores balanceadas AVL, Rubro-Negras, B-Trees Operações em árvores binárias de busca
Árvores Binárias - continuação
Tópicos Avançados em Estrutura de Dados 6º Período Ciência da Computação Uma Aplicação de Árvores Binárias Árvores Binárias - continuação As árvore binárias são estruturas importantes toda vez que uma
ALGORITMOS E ESTRUTURAS DE DADOS CES-11 CES-11 CES-11
ALGORITMOS E ESTRUTURAS DE DADOS Prof. Paulo André Castro [email protected] Sala 110 Prédio da Computação www.comp.ita.br/~pauloac IECE - ITA Uma árvore binária é: uma árvore vazia; ou uma árvore onde qualquer
Árvore Binária de Busca. Algoritmos e Estrutura de Dados II. Operações Busca e Sucessor. Árvore Binária de Busca. Árvores Rubro-Negras
Árvore Binária de Busca Algoritmos e Estrutura de Dados II Árvores Rubro-Negras Prof. Marco Aurélio Stefanes marco em dct.ufms.br Propriedades Se está na subárvore esquerda de então chave() chave() Se
Tipos de Dados, Tipos Abstratos de Dados Estruturas de Dados
Tipos de Dados, Tipos Abstratos de Dados Estruturas de Dados Tipo de dados, tipo abstrato de dados, estruturas de dados Termos parecidos, mas com significados diferentes Tipo de dado Em linguagens de programação
2ª Lista de Exercícios
Universidade Federal de Minas Gerais Departamento de Ciência da Computação Algoritmos e Estruturas de Dados II (Turmas M, N, W, F) 1º Semestre de 2012 Profs. Camilo Oliveira, Gisele Pappa, Ítalo Cunha,
DAS5102 Fundamentos da Estrutura da Informação
Pilhas A estrutura de dados Pilha emula a forma de organização de objetos intuitiva que é utilizada diariamente nos mais diversos contextos da vida humana. Containeres são empilhados e desempilhados diariamente
1. Introdução... 1 1.1. Definição... 1 1.2. Conceitos relacionados... 2
Índice i Índice Capítulo 4 Estrutura de Dados não sequencial com armazenamento não sequencial ( Árvore ) 1. Introdução... 1 1.1. Definição... 1 1.2. Conceitos relacionados... 2 2. Árvores binárias... 2
PROGRAMAÇÃO II 4. ÁRVORE
4. ÁRVORE PROGRAMAÇÃO II Prof. Jean Eduardo Glazar Uma árvore impõe uma estrutura hierárquica em uma coleção de itens. Um exemplo familiar é a árvore genealógica. Árvores despontam de forma natural em
Estruturas de Dados Árvores
Estruturas de Dados Árvores Prof. Eduardo Alchieri Árvores (introdução) Importância de estruturas unidimensionais ou lineares (vetores e listas) é inegável Porém, estas estruturas não são adequadas para
Algoritmos e Estrutura de Dados. Aula 13 Estrutura de Dados: Árvores de Pesquisa Binária Prof. Tiago A. E. Ferreira
Algoritmos e Estrutura de Dados Aula 13 Estrutura de Dados: Árvores de Pesquisa Binária Prof. Tiago A. E. Ferreira Introdução Uma árvore de pesquisa binária são estruturas de dados que admitem operações
Estruturas de Dados. Listas Dinâmicas Duplamente Encadeadas & Variantes. Listas Duplamente Encadeadas
Estruturas de Dados Listas Dinâmicas Duplamente Encadeadas & Variantes Prof. Ricardo J. G. B. Campello Listas Duplamente Encadeadas Listas simplesmente encadeadas são ineficientes para realizar certas
DAS5102 Fundamentos da Estrutura da Informação
Árvores Existe uma ampla variedade de dados que são comumente organizados sob a forma de árvores hierárquicas utilizadas recorrentemente em nosso dia a dia. Exemplos são a organização administrativa de
INF 1010 Estruturas de Dados Avançadas
INF 1010 Estruturas de Dados Avançadas Listas de Prioridades e Heaps 1 Listas de Prioridades Em muitas aplicações, dados de uma coleção são acessados por ordem de prioridade A prioridade associada a um
Árvores binárias de pesquisa com balanceamento. Algoritmos e Estruturas de Dados II
Árvores binárias de pesquisa com balanceamento Algoritmos e Estruturas de Dados II Árvores binárias de pesquisa Pior caso para uma busca é O(n) 1 3 Ordem de inserção: 1 3 2 4 5 6 2 4 5 6 2 Árvore completamente
ESTRUTURAS DE DADOS I. Notas de Aula. Prof. Dr. Gilberto Nakamiti
ESTRUTURAS DE DADOS I Notas de Aula 1 SUMÁRIO 1. INTRODUÇÃO... 2 1.1 Array (vetores)... 2 2. BUSCA DE ELEMENTOS... 3 2.1 Busca Seqüencial... 3 2.2 Busca Binária... 3 2.3 Busca Indexada... 3 2.4 Busca Hash...
Trabalho 3: Agenda de Tarefas
INF 1620 Estruturas de Dados Semestre 08.2 Trabalho 3: Agenda de Tarefas O objetivo deste trabalho é a implementação de um conjunto de funções para a manipulação de uma agenda de tarefas diárias, de forma
DAS5102 Fundamentos da Estrutura da Informação
Fila de Prioridade A fila de prioridade nada mais é que uma fila comum que permite que elementos sejam adicionados associados com uma prioridade. Cada elemento na fila deve possuir um dado adicional que
Algoritmos e Estruturas de Dados 2
Algoritmos e Estruturas de Dados 2 Unidade 1: Árvores binárias Rafael Beserra Gomes Universidade Federal do Rio Grande do Norte Material compilado em 21 de fevereiro de 201. Licença desta apresentação:
Figura 13.1: Um exemplo de árvore de diretório.
13. Árvores W. Celes e J. L. Rangel Nos capítulos anteriores examinamos as estruturas de dados que podem ser chamadas de unidimensionais ou lineares, como vetores e listas. A importância dessas estruturas
Árvores AVL. Estrutura de Dados II Jairo Francisco de Souza
Árvores AVL Estrutura de Dados II Jairo Francisco de Souza Introdução As árvores binárias de pesquisa são projetadas para um acesso rápido à informação. Idealmente a árvore deve ser razoavelmente equilibrada
Árvores Binárias Balanceadas Estrutura de Dados I
- entro de iências Exatas, Naturais e de Saúde Departamento de omputação Árvores inárias alanceadas Estrutura de Dados I OM06992 - Estrutura de Dados I Prof. Marcelo Otone guiar [email protected]
Algoritmos e Estruturas de Dados II. Trabalho Prático 2
Algoritmos e Estruturas de Dados II Entrega: 24/09/08 Devolução: 15/10/08 Trabalho individual Prof. Jussara Marques de Almeida Trabalho Prático 2 Você foi contratado pela XOL X Online para desenvolver
- UNIVERSIDADE DO VALE DO RIO DOS SINOS CIÊNCIAS EXATAS E TECNOLÓGICAS Curso: Informática / Ciência da Computação
Programação 1I Prof. Osório Árvores Genéricas Pag.: 1 - UNIVERSIDADE DO VALE DO RIO DOS SINOS CIÊNCIAS EXATAS E TECNOLÓGICAS Curso: Informática / Ciência da Computação Programação II Disciplina: Linguagem
ESTRUTURAS DE DADOS AVANÇADAS (INF 1010) (a) Seja um TAD definido por uma lista circular implementada em um vetor.
PUC-Rio Departamento de Informática Período: 2015.1 Horário: 2as-feiras e 4as-feiras de 17-19 30 de março de 2015 ESTRUTURAS DE DADOS AVANÇADAS (INF 1010) 1 a Lista de Exercícios 1. Lista (a) Seja um TAD
UNIVERSIDADE FEDERAL DO RIO GRANDE DO SUL INSTITUTO DE INFORMÁTICA INFORMÁTICA APLICADA
Responda 1) Quem desenvolveu a linguagem C? Quando? 2) Existe alguma norma sobre a sintaxe da linguagem C? 3) Quais são os tipos básicos de dados disponíveis na linguagem C? 4) Quais são as principais
Algoritmos e Estrutura de Dados III. Árvores
Algoritmos e Estrutura de Dados III Árvores Uma das mais importantes classes de estruturas de dados em computação são as árvores. Aproveitando-se de sua organização hierárquica, muitas aplicações são realizadas
INF 1010 Estruturas de Dados Avançadas. Árvores binárias
INF 1010 Estruturas de Dados Avançadas Árvores binárias 1 Árvore estrutura hierárquica: A B E F C D G A B C E F D G A B C D E F G (A (B (E, F)), C, (D (G))) 05/09/16 2 Árvore - definições árvore: nó raiz
Pesquisa digital. Algoritmos e Estruturas de Dados II
Pesquisa digital Algoritmos e Estruturas de Dados II Pesquisa digital A pesquisa digital usa a representação das chaves para estruturar os dados na memória Por exemplo, a representação de um número em
Á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
Programação II Conhecida também como: Árvore binária ordenada Árvore binária de busca Aresenta relação de ordem entre os nodos Ordem definida através do camo chamado chave CHAVE Prof. Mateus Raeder Chaves
FACULDADE CAMPO LIMPO PAULISTA MESTRADO EM CIÊNCIA DA COMPUTAÇÃO. Projeto e Análise de Algoritmos II Lista de Exercícios 2
FACULDADE CAMPO LIMPO PAULISTA MESTRADO EM CIÊNCIA DA COMPUTAÇÃO Projeto e Análise de Algoritmos II Lista de Exercícios 2 Prof. Osvaldo. 1. Desenvolva algoritmos para as operações abaixo e calcule a complexidade
Hashing. Rafael Nunes LABSCI-UFMG
Hashing Rafael Nunes LABSCI-UFMG Sumário Mapeamento Hashing Porque utilizar? Colisões Encadeamento Separado Endereçamento Aberto Linear Probing Double Hashing Remoção Expansão Quando não usar! Mapeamento
Sumário. 5COP096 Teoria da Computação Aula 8 Pesquisa em Memória Primária
5COP096 Teoria da Computação Aula 8 Prof. Dr. Sylvio Barbon Junior Sylvio Barbon Jr [email protected] 1 Sumário 1) Introdução à Pesquisa em Memória Primária 2) Pesquisa Sequencial 3) Pesquisa Binária 4) Árvore
ESTRUTURAS DE DADOS. prof. Alexandre César Muniz de Oliveira. 1. Introdução 2. Pilhas 3. Filas 4. Listas 5. Árvores 6. Ordenação 7. Busca 8.
ESTRUTURAS DE DADOS prof. Alexandre César Muniz de Oliveira 1. Introdução 2. Pilhas 3. Filas 4. Listas 5. Árvores 6. Ordenação 7. Busca 8. Grafos Sugestão bibliográfica: ESTRUTURAS DE DADOS USANDO C Aaron
Métodos de Pesquisa em Memória Primária
Algoritmos e Estrutura de Dados II Métodos de Pesquisa em Memória Primária Prof Márcio Bueno [email protected] / [email protected] Pesquisa Por pesquisa (procura ou busca) entende-se o ato
Algoritmos de Pesquisa e Ordenação em Vectores
Algoritmos de Pesquisa e Ordenação em Vectores FEUP - MIEEC Programação 2-2008/2009 Pesquisa Sequencial Problema (pesquisa de valor em vector): Verificar se um valor existe no vector e, no caso de existir,
ÁRVORES BINÁRIAS DE PESQUISA
ÁRVORES BINÁRIAS DE PESQUISA Árvores binárias de pesquisa são uma estrutura alternativa do tipo árvore binária, para guardar valores de tal forma que a recuperação dos mesmos pode ser efectuada de forma
Modelagem e Implementação (Incremental de um Software para Controle) de Aquário de Peixes
Modelagem e Implementação de Aquário de Peixes- por Jorge Fernandes - Página 1 Modelagem e Implementação (Incremental de um Software para Controle) de Aquário de Peixes Jorge Fernandes Natal, Agosto de
Estruturas de Dados. Parte dos slides a seguir são adaptações, extensões e traduções para C dos originais:
Estruturas de Dados Pilhas Prof. Ricardo J. G. B. Campello Créditos Parte dos slides a seguir são adaptações, extensões e traduções para C dos originais: disponíveis em http://ww3.datastructures.net/ cedidos
Persistência de Dados
Persistência de s Universidade do Estado de Santa Catarina - Udesc Centro de Ciências Tecnológicas - CCT Departamento de Ciência da Computação Tecnologia de Sistemas de Informação Estrutura de s II - DAD
Tabela de Símbolos. Análise Semântica A Tabela de Símbolos. Principais Operações. Estrutura da Tabela de Símbolos. Declarações 11/6/2008
Tabela de Símbolos Análise Semântica A Tabela de Símbolos Fabiano Baldo Após a árvore de derivação, a tabela de símbolos é o principal atributo herdado em um compilador. É possível, mas não necessário,
Algoritmos de Busca em Tabelas
Dentre os vários algoritmos fundamentais, os algoritmos de busca em tabelas estão entre os mais usados. Considere por exemplo um sistema de banco de dados. As operações de busca e recuperação dos dados
Árvores binárias de busca
Árvores binárias de busca Introdução à Ciência de Computação II Diego R. Amancio Baseado no material do Prof. Thiago A. S. Pardo Árvore binárias n Árvores de grau 2, isto é, cada nó tem dois filhos, no
BC1424 Algoritmos e Estruturas de Dados I. Aula 16: Árvores (introdução) Prof. Jesús P. Mena-Chalco. [email protected]
BC1424 Algoritmos e Estruturas de Dados I Aula 16: Árvores (introdução) Prof. Jesús P. Mena-Chalco [email protected] 1Q-2015 1 2 Árvores Uma árvore é uma estrutura de dados mais geral que uma lista
Exercício 1. Tabela 1: Cadastro de usuários, senhas e privilégios (exemplo). Login Senha Privilégio Armamento
1/5 Exercício 1 Um sistema de segurança militar, usado num submarino nuclear, controla o acesso de usuários a três subsistemas (armamento, navegação e comunicações) através da digitação do login do usuário
Algoritmos de pesquisa. Tabelas de dispersão/hash
Algoritmos de pesquisa Tabelas de dispersão/hash Introdução Motivação: Considerar o problema de pesquisar um determinado valor num vetor (array). Se o vetor não está ordenado, a pesquisa requer O(n) de
Árvores Binárias de Busca
Árvores AVL Árvores Binárias de Busca Altura de uma árvore binária (AB): igual à profundidade, ou nível máximo, de suas folhas A eficiência da busca em árvore depende do seu balanceamento Algoritmos de
Projeto 1: Aprovação de Transação de Cartão de Crédito
Projeto da disciplina de Algoritmos e Estrutura de Dados Departamento de Estatística e Informática Universidade Federal Rural de Pernambuco Prof. Tiago A. E. Ferreira Projeto 1: Aprovação de Transação
Introdução a AVL: teoria e prática. 22/11, 25/11 e 30/11
Introdução a AVL: teoria e prática 22/11, 25/11 e 30/11 Árvores binárias de busca (ABB) Árvores de grau 2, isto é, cada nó tem dois filhos, no máximo Raiz B A C Terminologia: filho esquerdo filho direito
Orientação a Objetos
1. Domínio e Aplicação Orientação a Objetos Um domínio é composto pelas entidades, informações e processos relacionados a um determinado contexto. Uma aplicação pode ser desenvolvida para automatizar ou
Classificação e Pesquisa de Dados
Classificação e Pesquisa de Dados Aula 20 Árvores B e B+ B-Trees (Árvores B) [Bayer & McCreight 1970] UFRGS INF01124 B-Trees (Árvores B) Árvores de pesquisa balanceadas, projetadas para minimizar o tempo
Implementação de um analisador léxico: a primeira etapa na construção do compilador Marvel
Implementação de um analisador léxico: a primeira etapa na construção do compilador Marvel Cláudio Lopes (peso 0.3), Gildo Leonel (peso 0.3), Sérgio Rossini (peso 0.3) 1. Visão Geral Departamento de Ciência
Manual. Atualização nº 1160 Novembro/2015 23/11/2015
1 Manual Atualização nº 1160 Novembro/2015 23/11/2015 NOVOS RECURSOS 2 01.01 Contrato de Colocação e Termo de Responsabilidade. 3 Se preferir, modifique os dados, alterando o tamanho da fonte e o texto.
Algoritmos e Estrutura de Dados II. Árvore AVL. Prof a Karina Oliveira. Fonte: Prof a Ana Eliza
Algoritmos e Estrutura de Dados II Árvore AVL Prof a Karina Oliveira [email protected] Fonte: Prof a Ana Eliza Árvores Binárias de Busca Objetivo da Utilização Minimizar o número de comparações efetuadas,
Árvores Binárias. Observação: Material elaborado a partir do material do Professor Marcos Costa.
Árvores Binárias Observação: Material elaborado a partir do material do Professor Marcos Costa. Árvores Binárias Árvore binária é definida como um conjunto finito de nós que Ou está vazio Ou consiste de
INF 1007 Programação II
INF 1007 Programação II Aula 08 Busca em Vetor Edirlei Soares de Lima Busca em Vetor Problema: Entrada: vetor v com n elementos; elemento d a procurar; Saída: m se o elemento procurado
Organização do Curso. Instalação e Configuração. Módulo II. Pós Graduação em Projeto e Gerencia de Redes de Computadores
1 Pós Graduação em Projeto e Gerencia de Redes de Computadores Sistemas Operacionais de Redes I - Linux Prof.: Nelson Monnerat Instalação e Configuração 1 Sistemas Operacionais de Redes I - Linux Módulo
