Resumen: mostrar cómo usar la función qsort
(presente en stdlib.h
) de C para ordenar arreglos usando una función incorporada en el lenguaje, sin programar métodos propios.
Aunque ya vimos cómo hacer el ordenamiento de burbuja y el ordenamiento QuickSort a mano, hoy vamos a ver cómo usar una función incorporada en C para ordenar arreglos. La función se llama qsort
.
Por cierto, el uso de esta función ya la vimos en otro algoritmo.
Es una función presente dentro de stdlib.h
. Ordena un arreglo internamente, es decir, lo modifica. Tiene varias implementaciones y la mayoría de veces usa quicksort internamente, pero no debemos confiar en ello.
Tampoco deberíamos preocuparnos, pues está programada de la mejor manera. Su sintaxis es:
qsort(arreglo, longitud del arreglo, tamaño de cada elemento del arreglo, función que compara)
En donde:
sizeof
Veamos un ejemplo rápido. Antes de invocar a qsort
debemos definir el arreglo, su longitud y el tamaño de un elemento del mismo. Así:
int arreglo[] = {28, 11, 96, 21, 97, 6, 18, 13, 1};
int tamanioElemento = sizeof arreglo[0];
int longitud = sizeof arreglo / tamanioElemento;
Después debemos definir la función que compara:
int funcionQueCompara(const void *a, const void *b) {
// Castear a enteros
int aInt = *(int *) a;
int bInt = *(int *) b;
// Al restarlos, se debe obtener un número mayor, menor o igual a 0
// Con esto ordenamos de manera ascendente
return aInt - bInt;
}
Como ves, esta función devolverá lo que resulte de operar a - b
como enteros, eso devolverá 0, un negativo o un positivo que servirá para ordenarlos de manera ascendente.
Después ya podemos invocar a qsort
:
qsort(arreglo, longitud, tamanioElemento, funcionQueCompara);
El código completo para ordenar un arreglo de manera ascendente en C usando qsort
es:
/**
* Ordenar arreglos en C usando la función incorporada "qsort"
*
* @author parzibyte
* @see https://parzibyte.me/blog
* */#include <stdio.h>
#include <stdlib.h>
int funcionQueCompara(const void *a, const void *b) {
// Castear a enteros
int aInt = *(int *) a;
int bInt = *(int *) b;
// Al restarlos, se debe obtener un número mayor, menor o igual a 0
// Con esto ordenamos de manera ascendente
return aInt - bInt;
}
int main(void) {
int arreglo[] = {28, 11, 96, 21, 97, 6, 18, 13, 1};
int tamanioElemento = sizeof arreglo[0];
int longitud = sizeof arreglo / tamanioElemento;
printf("Imprimendo arreglo antes de ordenar\n");
for (int x = 0; x < longitud; x++) {
printf("%d ", arreglo[x]);
}
qsort(arreglo, longitud, tamanioElemento, funcionQueCompara);
printf("\nImprimendo arreglo ya ordenado\n");
for (int x = 0; x < longitud; x++) {
printf("%d ", arreglo[x]);
}
return 0;
}
Con la siguiente salida:
Para usar qsort
en C y ordenar el arreglo de manera descendente solo debemos cambiar la función que compara, regresando lo que se obtiene de b - a
. Así:
int funcionQueCompara(const void *a, const void *b) {
// Castear a enteros
int aInt = *(int *) a;
int bInt = *(int *) b;
// Al restarlos, se debe obtener un número mayor, menor o igual a 0
// Con esto ordenamos de manera descendente
return bInt - aInt;
}
De manera que el código completo es el siguiente:
/**
* Ordenar arreglos en C usando la función incorporada "qsort"
*
* @author parzibyte
* @see https://parzibyte.me/blog
* */#include <stdio.h>
#include <stdlib.h>
int funcionQueCompara(const void *a, const void *b) {
// Castear a enteros
int aInt = *(int *) a;
int bInt = *(int *) b;
// Al restarlos, se debe obtener un número mayor, menor o igual a 0
// Con esto ordenamos de manera descendente
return bInt - aInt;
}
int main(void) {
int arreglo[] = {28, 11, 96, 21, 97, 6, 18, 13, 1};
int tamanioElemento = sizeof arreglo[0];
int longitud = sizeof arreglo / tamanioElemento;
printf("Imprimendo arreglo antes de ordenar\n");
for (int x = 0; x < longitud; x++) {
printf("%d ", arreglo[x]);
}
qsort(arreglo, longitud, tamanioElemento, funcionQueCompara);
printf("\nImprimendo arreglo ya ordenado\n");
for (int x = 0; x < longitud; x++) {
printf("%d ", arreglo[x]);
}
return 0;
}
Al ejecutarlo se obtiene:
Con esta función se pueden ordenar todo tipo de arreglos, en este caso lo hicimos con enteros. Recuerda que puedes ver otro ejemplo para ordenar una cadena aquí.
Si quieres, puedes ver cómo hacer manualmente el método de la burbuja o el método quicksort.
Finalmente te invito a ver más tutoriales de C aquí.
El día de hoy te mostraré cómo crear un servidor HTTP (servidor web) en Android…
En este post te voy a enseñar a designar una carpeta para imprimir todos los…
En este artículo te voy a enseñar la guía para imprimir en una impresora térmica…
Hoy te voy a mostrar un ejemplo de programación para agregar un módulo de tasa…
Los usuarios del plugin para impresoras térmicas pueden contratar licencias, y en ocasiones me han…
Hoy voy a enseñarte cómo imprimir el € en una impresora térmica. Vamos a ver…
Esta web usa cookies.