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: 899 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 <stdio.h>
#include <stdlib.h>
#include <locale.h>

// 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);

// função principal do programa
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;
	
  setlocale(LC_ALL,""); // para acentos do português
  
  // vamos mostrar o vetor na ordem original
  printf("Vetor na ordem original: ");
  for(i = 0; i < tam; i++){
    printf("%d ", 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
  printf("\nVetor ordenado: ");
  for(i = 0; i < tam; i++){
    printf("%d ", valores[i]);
  }
  
  printf("\n\n");
  system("PAUSE");	
  return 0;
}

// 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
  // do primeiro elemento e vai até o penúltimo elemento
  for (i = 0; i < n - 1; i++){
    // encontramos o menor elemento do sub-vetor que ainda
    // não foi ordenado


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