Bubble Sort em Java
Publicado por Mariana Ribeiro Mendes (última atualização em 29/09/2012)
[ Hits: 10.307 ]
Bubble Sort
É um dos algoritmos mais simples e é indicado apenas para quando se há uma pequena quantidade de dados. Sua implementação é simples, ele percorre uma lista de dados várias vezes, e em cada passagem pela lista ele leva o maior elemento que ele encontrar naquela sequencia para o final (última posição possível para sua colocação).
Complexidade do pior caso: O (n²)
Complexidade do caso médio: O(n²)
Complexidade do melhor caso: n
Espero que gostem. Qualquer dúvida ou discordância, sintam-se livres para me contatar.
Abraços.
import java.util.Scanner; //Inicio da classe BubbleSort public class BubbleSort { //Método bubbleSort, ele é quem faz a ordenação public static void bubbleSort (int[] dados){ /** * Inicia a variável que verifica se houve alguma troca entre os items. * Ela é inicializada como true para poder entrar no laço que garantirá que o * vetor seja organizado até o final, quantas vezes forem necessárias. */ boolean troca = true; //Laço que garante que o vetor seja verificado quantas vezes forem necessárias while (troca) { /** * Muda o estado da variável troca para que o laço funcione corretamente. * Se ela entrar no for, e seu estado não for mudado para true, significa que não * são mais necessárias verificações no vetor. */ troca = false; /** * Este for realiza apenas uma volta no vetor, o que pode não ser suficiente * para a total organização dos itens. */ for (int posicao = 0; posicao < (dados.length)-1; posicao++){ /** * Se o dado da posição atual for maior que o dado da próxima posição, * é realizado uma troca entre eles. */ if (dados[posicao] > dados[posicao+1]){ //Copia o valor da próxima posição para uma variável auxiliar int variavelAuxiliar = dados[posicao+1]; //Coloca o valor da posição atual na próxima posição dados[posicao+1] = dados[posicao]; //A posição atual recebe o valor que foi copiado para a variável auxiliar dados[posicao] = variavelAuxiliar; /** * Seta true para a troca, indicando que houve troca, evitando assim que * o vetor não seja verificado uma próxima vez. * Caso o vetor seja percorrido sem trocas, a variável continuará false * indicando que não há mais necessidade de verificações no vetor. */ troca = true; } } } //Chama uma função para exibir os dados já organizados. imprime(dados); } //Fim do bubbleSort //Função que imprime os dados organizados. public static void imprime(int[] dados){ //Para cada iteração do for, ele imprime o dado que estiver na posição indicada pelo variável. for (int posicao = 0; posicao < dados.length; posicao++ ){ System.out.println(dados[posicao]); } } //Função principal, onde começa a execução. public static void main(String[] args) { //Cria um vetor de 10 posições. int[] dados = new int[10]; //Cria uma instancia de Scanner para realizar a leitura dos valores. Scanner in = new Scanner(System.in); //Para cada iteração do for ele lê um valor. for (int posicao = 0; posicao < dados.length; posicao++ ){ System.out.println("Entre com um valor"); dados[posicao] = in.nextInt(); } //Chama o método bubbleSort para ordenar os dados recebidos. bubbleSort(dados); } }
Calculadora básica e simples de entender
Cronômetro e/ou agendador de tarefas em Java
primeiros exemplos usando metodos
Atualizando o Passado: Linux no Lenovo G460 em 2025
aaPanel - Um Painel de Hospedagem Gratuito e Poderoso
O macete do Warsaw no Linux Mint e cia
Visualizar arquivos em formato markdown (ex.: README.md) pelo terminal
Dando - teoricamente - um gás no Gnome-Shell do Arch Linux
Como instalar o Google Cloud CLI no Ubuntu/Debian
Mantenha seu Sistema Leve e Rápido com a Limpeza do APT!
Procurando vídeos de YouTube pelo terminal e assistindo via mpv (2025)
Será que eu deveria apreender C/C++ para desenvolver para Linux? (3)
O 1º artigo a gente nunca esquece (3)
Pastas da raiz foram para a área de trabalho [RESOLVIDO] (9)