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.955 ]
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 - Listas Duplamente Encadeadas
Linguagem C - Funções Variádicas
Análise dos Métodos de Ordenação usados em Algoritmos Computacionais
Guia de Programação em C/GTK 2 - Construindo uma Calculadora Completa
Linguagem C - Listas Duplamente Encadeadas
Faça suas próprias atualizações de pacotes/programas no Void Linux e torne-se um Contribuidor
Como rodar o Folding@home no Linux
Criando um painel de controle (Dashboard) para seu servidor com o Homepage
O Abismo entre o Código e o Chão: Saltos Tecnológicos e a Exclusão Estrutural no Brasil
Instalar e Configurar a santíssima trindade (PAP) no Void Linux
Pisando no acelerador do Linux Mint: Kernel XanMod, zRAM e Ajustes de Swap
Como compilar kernel no Linux Mint
Lançamento do Brutal DOOM test 6
Consertando o erro no Brave de webgl
Solução para ter de volta as bordas e barra de títulos das janelas em zenity no Debian 13.x
Seno, Coseno, Tangente em CLIPPER (0)
Inserir uma URL num arquvo pelo Ubuntu (CLIPPER) (0)
VMWare Player não conecta na rede nem consigo intercambiar arquivos (1)









