Algoritmo de ordenação Quick Sort
Publicado por João Cristiano Monteiro da Silva (última atualização em 30/11/2010)
[ Hits: 10.422 ]
Algoritmo que implementa a ordenação quick sort, aplicando o conceito de template (permite reutilização de código) e partição, conceito amplamente abordado para explicar esse tipo de ordenação.
#include <iostream>
#include <stdlib.h>
using namespace std;
template <typename T>
void troca(T *a, T *b) {
T aux = *a;
*a = *b;
*b = aux;
}
template <typename T>
void quicksort(T aux[], int inicio, int fim) {
if (fim > inicio) {
int retorno = particao(aux, inicio, fim);
quicksort(aux, inicio, retorno - 1);
quicksort(aux, retorno + 1, fim);
}
}
template <typename T>
int particao(T aux[], int inicio, int fim) {
int temp = inicio;
while (true) {
while (aux[inicio] <= aux[temp]) inicio++;
while (aux[fim] > aux[temp]) fim--;
if (fim < inicio) {
troca(&aux[temp], &aux[fim]);
return (fim);
}
troca(&aux[inicio], &aux[fim]);
}
}
int main(int argc, char **argv) {
//int vetor[8] = {25, 32, 12, -8, 9, 220, 5, 1};
//double vetor[8] = {25.56, 32.12, 12.89, -8.54, 9.08, 220.54, 5.48, 1.56};
char vetor[8] = {'h', 'a', 'd', 'e', 'f', 'g', 'b', 'c'};
cout << "Vetor original: " << endl;
for (int i = 0; i < 8; i++) {
cout << "Posicao " << i << " = " << vetor[i] << endl;
}
cout << endl << endl;
cout << "Vetor ordenado: " << endl;
quicksort(vetor, 0, 7);
for (int i = 0; i < 8; i++) {
cout << "Posicao " << i << " = " << vetor[i] << endl;
}
return (EXIT_SUCCESS);
}
Funções com número variável de argumentos
[C] Listas Duplamente Encadeadas
Nenhum comentário foi encontrado.
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
IA chega ao desktop e impulsiona produtividade no mundo Linux
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?
Programa fora de escala na tela do pc (40)
\Boot sem espaço em disco (Fedora KDE Plasma 42) (5)
Preciso recuperar videos *.mp4 corrompidos (0)









