QuickSort Genérico
Publicado por Caio Dutra (última atualização em 11/08/2011)
[ Hits: 6.678 ]
Implementação de um algoritmo de ordenação (Quick Sort) que recebe qualquer tipo de dado, desde que receba também como parâmetro, uma simples função de comparação.
/* -- sort.h Biblioteca para ordenação de vetores pelo método quicksort. Este algoritmo já vem disponível na biblioteca padrão da linguagem C, mas criei minha própria versão para fins didáticos. Copyright (c) Caio Dutra 2010 <caiodutra_bh@yahoo.com.br> - BHzte/MG/Brasil */ #ifndef _SORT_H #ifdef __cplusplus extern "C" { #endif // --- Tools functions static void *access_at ( void *vetor, int pos, int tam ) { char *_r = (char *) vetor; _r += pos * tam; return ((void *)_r); } static void _swap ( void *a, void *b, int tam ) { char *i_a, *i_b, i, temp; i_a = (char *)a; i_b = (char *)b; for ( i = 0; i < tam; i++ ) { temp = *i_a; *i_a = *i_b; *i_b = temp; i_a++; i_b++; } } /* - quicksort method - */ #define _GENERIC_QUICKSORT #if defined(_GENERIC_QUICKSORT) // Quick sort static void quicksort ( void *_array, int pos_i, int pos_f, int typesize, int (*comp)( const void *, const void *)); #else void quicksort ( int *_array, int pos_i, int pos_f ); #endif static int quicksort_part ( void *vetor, int pos_x, int pos_y, int sz, int (*cmp)(const void *, const void *) ) { int x = pos_x, y = pos_y; // O pivot está em X while ( 1 ) { while ( x < y && cmp (access_at ( vetor, x, sz ), access_at ( vetor, y, sz )) <= 0 ) --y; if ( x < y ) _swap ( access_at ( vetor, x, sz ), access_at ( vetor, y, sz ),sz); // Agora, o pivot está em Y else break; while ( x < y && cmp (access_at ( vetor, y, sz ), access_at ( vetor, x, sz )) >= 0 ) ++x; if ( x < y ) _swap ( access_at ( vetor, x, sz ), access_at ( vetor, y, sz ),sz); // Agora o pivot está em X else break; } return (y); } static void quicksort ( void *vetor, int pos_x, int pos_y, int sz, int (*cmp)(const void *, const void *) ) { if ( pos_x < pos_y ) { int _r = quicksort_part ( vetor, pos_x, pos_y, sz, cmp ); quicksort ( vetor, pos_x, _r - 1, sz, cmp ); quicksort ( vetor, _r + 1, pos_y, sz, cmp ); } } #ifdef __cplusplus } #endif #define _SORT_H #endif /* _SORT_H */
Estrutura de dados: Lista dinâmica duplamente encadeada
S. MarioBros - Editor de fase 0.1
Nenhum comentário foi encontrado.
Atenção a quem posta conteúdo de dicas, scripts e tal (1)
Manutenção de sistemas Linux Debian e derivados com apt-get, apt, aptitude e dpkg
Melhorando o tempo de boot do Fedora e outras distribuições
Como instalar as extensões Dash To Dock e Hide Top Bar no Gnome 45/46
Como Atualizar Fedora 39 para 40
Instalar Google Chrome no Debian e derivados
Consertando o erro do Sushi e Wayland no Opensuse Leap 15
Instalar a última versão do PostgreSQL no Lunix mantendo atualizado
Flathub na sua distribuição Linux e comandos básicos de gerenciamento
ASRock H310CM-HG4 vs Linux (10)
erro ao clonar repo github (8)
iso de sistema 32 bit em atividade (1)