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.175 ]
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
Linguagem C - Listas Duplamente Encadeadas
Análise dos Métodos de Ordenação usados em Algoritmos Computacionais
Guia de Programação em C/GTK 2 - Construindo uma Calculadora Completa
Dicas para aprender programação
IA Turbina o Desktop Linux enquanto distros renovam forças
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
Atualizando o Fedora 42 para 43
Como saber se o seu e-mail já teve a senha vazada?
Como descobrir se a sua senha já foi vazada na internet?
VOL já não é mais como antes? (6)
É normal não gostar de KDE? (12)
E aí? O Warsaw já está funcionando no Debian 13? [RESOLVIDO] (15)
Secure boot, artigo interessante, nada técnico. (4)
copiar library para diretorio /usr/share/..... su com Falha na a... (1)









