Ofereço ajuda em Java, C/C++, Python, C#, LISP, AutoLisp, AutoCAD
+55 (062) 98553-6711
Ofereço ajuda em PHP, Python, C#, JavaScript, Laravel, Google Ads e SEO
+55 (062) 98243-1195

Você está aqui: Java ::: Desafios e Lista de Exercícios Resolvidos ::: Estruturas de Dados - Árvores Binárias e Árvores Binárias de Busca

Como criar uma árvore binária de busca em Java a partir dos elementos de um vetor de inteiros - Desafio de Programação Resolvido em Java

Quantidade de visualizações: 759 vezes
Pergunta/Tarefa:

Escreva um programa Java que declara, constrói e inicializa o seguinte vetor de inteiros:

// vamos declarar um vetor de 10 inteiros
// sem repetição
int valores[] = {5, 1, 19, 7, 25, 8, 3, 40, 2, 6};
Uma vez criado o vetor de inteiros, crie um árvore binária de busca e insira todos os elementos do vetor na árvore, obedecendo a regra de que os valores menores que a raiz ou o nó pai deverão ser colocados à esquerda e os maiores à direita. Valores repetidos não são permitidos em uma árvore binária de busca.

Após a inserção dos elementos do vetor na árvore binária de busca, mostre todos os nós da árvore usando o percurso "em ordem". O percurso em ordem é usado quando queremos exibir os valores dos nós da árvore binária de busca em ordem ascendente. Neste tipo de percurso nós visitamos primeiramente a sub-árvore da esquerda, então o nó atual e finalmente a sub-árvore à direita do nó atual. É importante notar que esta travessia é feita por meio de um método recursivo.

Sua saída deve ser parecida com:

Valores do array: [5, 1, 19, 7, 25, 8, 3, 40, 2, 6]
Valores na árvores binária: 1 2 3 5 6 7 8 19 25 40
Resposta/Solução:

Veja a resolução comentada deste exercício usando Java:

----------------------------------------------------------------------
Precisa de ajuda? Chama no WhatsApp +55 (62) 98553-6711 (Osmar)

Este código foi útil? Paga um cafezinho pra mim :-(
PIX: osmar@arquivodecodigos.com.br 
----------------------------------------------------------------------

package estudos;

import java.util.Arrays;

// classe interna para representar os nós da
// árvore binária
class No {
  int valor; // valor armazenado no nó
  No esquerdo; // filho esquerdo
  No direito; // filho direito
  
  // construtor do nó
  public No(int valor){
    this.valor = valor;
    this.esquerdo = null;
    this.direito = null;
  }
}

public class Estudos { 
  // referência para a raiz da árvore
  static No raiz;
  
  public static void main(String args[]){
    // vamos declarar um vetor de 10 inteiros
    // sem repetição
    int valores[] = {5, 1, 19, 7, 25, 8, 3, 40, 2, 6};
    
    // vamos mostrar os valores do vetor
    System.out.println("Valores do array: " + 
      Arrays.toString(valores));
    
    // vamos percorrer os valores do vetor e adicioná-los
    // à arvore binária
    for (int i = 0; i < valores.length; i++) {
      inserir(valores[i]);
    }
    
    // agora vamos exibir os valores já inseridos na
    // árvore binária usando o percurso "Em Ordem", que
    // devolve os nós da árvore ordenados em ordem
    // crescente
    System.out.print("Valores na árvores binária: ");
    em_ordem();
    System.out.println();
  }
  
  // função usada para inserir um novo nó na árvore
  // retorna true se o nó for inserido com sucesso e false
  // se o elemento não puder ser inserido (no caso 
  // de já existir um elemento igual)
  public static boolean inserir(int valor){
    // a árvore ainda está vazia?
    if(raiz == null){
      // vamos criar o primeiro nó e definí-lo como a
      // raiz da árvore
      raiz = new No(valor); // cria um novo nó
    }
    else{
      // localiza o nó pai do novo nó
      No pai = null;
      No no_atual = raiz; // começa a busca pela raiz
   
      // enquanto o nó atual for diferente de null
      while(no_atual != null){
        // o valor sendo inserido é menor que o nó atual?
        if(valor < no_atual.valor) {
          pai = no_atual;
          // vamos inserir do lado esquerdo
          no_atual = no_atual.esquerdo;
        }
        // o valor sendo inserido é maior que o nó atual
        else if(valor > no_atual.valor){
          pai = no_atual;
          // vamos inserir do lado direito
          no_atual = no_atual.direito;
        }
        else{
          return false; // um nó com este valor foi encontrado
        }
      }
         
      // cria o novo nó e o adiciona como filho do nó pai
      if(valor < pai.valor){
         pai.esquerdo = new No(valor);
      }
      else{
        pai.direito = new No(valor);
      }
    }
  
    // retorna true para indicar que o novo nó foi inserido
    return true; 
  }

  // função que permite disparar a travessia em-ordem
  public static void em_ordem(){
    em_ordem(raiz);
  }
  
  // sobrecarga da função em ordem com uma parâmetro (esta é a versão 
  // recursiva da função)
  private static void em_ordem(No raiz){
    if(raiz == null){ // condição de parada
      return;
    }
      
    // visita a sub-árvore da esquerda
    em_ordem(raiz.esquerdo);
    // visita o nó atual
    System.out.print(raiz.valor + " ");
    // visita a sub-árvore da direita
    em_ordem(raiz.direito);
  }
}


Link para compartilhar na Internet ou com seus amigos:

Mais Desafios de Programação e Exercícios e Algoritmos Resolvidos de Java

Veja mais Dicas e truques de Java

Dicas e truques de outras linguagens

E-Books em PDF

E-Book 350 Exercícios Resolvidos de Java - PDF com 500 páginas
Domine lógica de programação e a linguagem Java com o nosso E-Book 350 Exercícios Exercícios de Java, para você estudar onde e quando quiser.

Este e-book contém exercícios resolvidos abrangendo os tópicos: Java básico, matemática e estatística, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book
E-Book 650 Dicas, Truques e Exercícios Resolvidos de Python - PDF com 1.200 páginas
Domine lógica de programação e a linguagem Python com o nosso E-Book 650 Dicas, Truques e Exercícios Exercícios de Python, para você estudar onde e quando quiser.

Este e-book contém dicas, truques e exercícios resolvidos abrangendo os tópicos: Python básico, matemática e estatística, banco de dados, programação dinâmica, strings e caracteres, entrada e saída, estruturas condicionais, vetores e matrizes, funções, laços, recursividade, internet, arquivos e diretórios, programação orientada a objetos e muito mais.
Ver Conteúdo do E-book

Linguagens Mais Populares

1º lugar: Java
2º lugar: Python
3º lugar: C#
4º lugar: PHP
5º lugar: C
6º lugar: Delphi
7º lugar: JavaScript
8º lugar: C++
9º lugar: VB.NET
10º lugar: Ruby



© 2025 Arquivo de Códigos - Todos os direitos reservados
Neste momento há 20 usuários muito felizes estudando em nosso site.