Linguagem C - Árvores Binárias
Neste artigo, falarei sobre o que é e como implementar uma estrutura de dados chamada Árvore Binária. Com tempos de pesquisa, inserção e remoção expressivamente melhores que de listas encadeadas, esta estrutura é usada principalmente em bancos de dados e sistemas de arquivos.
[ Hits: 51.241 ]
Por: Enzo de Brito Ferber em 07/05/2015 | Blog: http://www.maximasonorizacao.com.br
/* @ Folha deletar (Folha raiz, int info) * * Argumentos * ---------- * raiz raiz principal da arvore * info informação procurada para deletar * * Retorno * ------- * raiz em ambos os casos (erro e sucesso) */ Folha deletar (Folha raiz, int info) { Folha filho, n_raiz; if (!raiz) return NULL; if (raiz->info == info) { if (raiz->direita) { n_raiz = filho = raiz->direita; while(filho->esquerda) filho = filho->esquerda; filho->esquerda = raiz->esquerda; free (raiz); return n_raiz; } else { n_raiz = raiz->esquerda; free (raiz); return n_raiz; } } else if (info > raiz->info) raiz->direita = deletar(raiz->direita, info); else raiz->esquerda = deletar(raiz->esquerda, info); return raiz; }
Folha deletar (Folha raiz, int info)
Folha filho, n_raiz; if (!raiz) return NULL;
if (raiz->info == info) { // (tratamento dos casos de remoção) } else if (info > raiz->info) raiz->direita = deletar(raiz->direita, info); else raiz->esquerda = deletar(raiz->esquerda, info); return raiz;
if (raiz->direita) { n_raiz = filho = raiz->direita; while(filho->esquerda) filho = filho->esquerda; filho->esquerda = raiz->esquerda; free (raiz); return n_raiz; } else { n_raiz = raiz->esquerda; free (raiz); return n_raiz; }
while(filho->esquerda) filho = filho->esquerda;
filho->esquerda = raiz->esquerda;
free (raiz); return n_raiz;
else { n_raiz = raiz->esquerda; free (raiz); return n_raiz; }
Linguagem C - Funções Variádicas
Linguagem C - Listas Duplamente Encadeadas
Guia de Programação em C/GTK 2 - Construindo uma Calculadora Completa
Dicas para aprender programação
Linguagem C - Listas Duplamente Encadeadas
Compartilhando a tela do Computador no Celular via Deskreen
Como Configurar um Túnel SSH Reverso para Acessar Sua Máquina Local a Partir de uma Máquina Remota
Configuração para desligamento automatizado de Computadores em um Ambiente Comercial
Como renomear arquivos de letras maiúsculas para minúsculas
Imprimindo no formato livreto no Linux
Vim - incrementando números em substituição
Efeito "livro" em arquivos PDF
Como resolver o erro no CUPS: Unable to get list of printer drivers
Instalação Uefi com o instalador clássico do Mageia (1)
Vou voltar moderar conteúdos de Dicas e Artigos (0)
[Python] Automação de scan de vulnerabilidades
[Python] Script para analise de superficie de ataque
[Shell Script] Novo script para redimensionar, rotacionar, converter e espelhar arquivos de imagem
[Shell Script] Iniciador de DOOM (DSDA-DOOM, Doom Retro ou Woof!)
[Shell Script] Script para adicionar bordas às imagens de uma pasta