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: C++ ::: Dicas & Truques ::: Ordenação e Pesquisa (Busca)

Como usar a ordenação Selection Sort em C++ - Ordenação por Seleção em C++

Quantidade de visualizações: 771 vezes
Nesta dica mostrarei os detalhes da ordenação Selection Sort e como implementá-la em C++. Também chamada de Ordenação por Seleção, esta ordenação classifica o array (ou vetor) de forma repetitiva procurando sempre o menor elemento na parte não ordenada do vetor e movendo-o para a parte já ordenada. Mencionei menor elemento para o caso da classificação em ordem crescente. Se for ordem decrescente então deveremos buscar sempre o maior elemento.

Considerando o vetor [1, 6, 9, 3, 7, 8, 5, 2] nós teremos as iterações do laço externo e do laço interno, resultando nas seguintes trocas de elementos:

Troca 1:
2 trocou de lugar com 6
Resultado: [1, 2, 9, 3, 7, 8, 5, 6]

Troca 2:
3 trocou de lugar com 9
Resultado: [1, 2, 3, 9, 7, 8, 5, 6]

Troca 3:
5 trocou de lugar com 9
Resultado: [1, 2, 3, 5, 7, 8, 9, 6]

Troca 4:
6 trocou de lugar com 7
Resultado: [1, 2, 3, 5, 6, 8, 9, 7]

Troca 5:
7 trocou de lugar com 8
Resultado: [1, 2, 3, 5, 6, 7, 9, 8]

Troca 6:
8 trocou de lugar com 9
Resultado: [1, 2, 3, 5, 6, 7, 8, 9]

Veja agora o código C++ completo para a ordenação Selection Sort. Coloquei comentários detalhados para facilitar o seu entendimento do algorítmo:

#include <string>
#include <iostream>

using namespace std;

// protótipo da função que usa a ordenação Selection Sort para
// ordenar um array de inteiros
void ordenar_selection_sort(int vetor[], int tam);

int main(int argc, char *argv[]){
  // vamos criar um vetor de inteiros
  int valores[] = {1, 6, 9, 3, 7, 8, 5, 2};
  int tam = 8;
  int i;
	
  // vamos mostrar o vetor na ordem original
  cout << "Vetor na ordem original: ";
  for(i = 0; i < tam; i++){
    cout << valores[i] << " ";
  }
	
  // agora vamos usar a ordenação Selection Sort
  // para ordenar o vetor em ordem crescente
  ordenar_selection_sort(valores, tam);
    
  // e agora vamos mostrar o vetor ordenado
  cout << "\nVetor ordenado: ";
  for(i = 0; i < tam; i++){
    cout << valores[i] << " ";
  }
  
  cout << "\n\n";
  system("PAUSE"); // pausa o programa
  return EXIT_SUCCESS; 
}

// função que usa a ordenação Selection Sort para
// ordenar um array de inteiros
void ordenar_selection_sort(int vetor[], int tam){
  // vamos obter o tamanho do vetor    
  int n = tam;
  int i, j, indice_menor_elemento; 
 
  // o laço externo percorre os elementos do vetor a partir


Por apresentar laços aninhados (um laço externo e um interno), a ordenação Selection Sort não é recomendada para grandes conjuntos de dados, visto que sua complexidade de tempo é de O(n2).

Link para compartilhar na Internet ou com seus amigos:

Desafios, Exercícios e Algoritmos Resolvidos de C++

Veja mais Dicas e truques de C++

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á 35 usuários muito felizes estudando em nosso site.