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: 53.385 ]
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
Dicas para aprender programação
Guia de Programação em C/GTK 2 - Construindo uma Calculadora Completa
Análise dos Métodos de Ordenação usados em Algoritmos Computacionais
Cirurgia para acelerar o openSUSE em HD externo via USB
Void Server como Domain Control
Modo Simples de Baixar e Usar o bash-completion
Monitorando o Preço do Bitcoin ou sua Cripto Favorita em Tempo Real com um Widget Flutuante
Como impedir exclusão de arquivos por outros usuários no (Linux)
Cirurgia no Linux Mint em HD Externo via USB
Anúncio do meu script de Pós-Instalação do Ubuntu
Duas Pasta Pessoal Aparecendo no Ubuntu 24.04.3 LTS (5)
Formas seguras de instalar Debian Sid (0)
Alguém pode me indicar um designer freelancer? [RESOLVIDO] (4)
Alguém executou um rm e quase mata a Pixar! (1)
Por que passar nas disciplinas da faculdade é ruim e ser reprovado é b... (6)









