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.

Sobre qsort

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:

  1. Arreglo: el arreglo que queremos ordenar con qsort. Debemos pasar un apuntador al inicio del mismo
  2. Longitud del arreglo: el tamaño del arreglo, o sea, su longitud o cantidad de elementos. Mira aquí cómo se obtiene la longitud.
  3. Tamaño de cada elemento: cuánto ocupa una variable del arreglo, se puede obtener con sizeof
  4. Función que compara: una función que debe devolver 0, un valor negativo o uno positivo indicando cómo ordenar un elemento en comparación con otro (así podemos ordenar de manera ascendente o descendente).

Ordenar arreglo con qsort

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í:

See the gist on github.

Después debemos definir la función que compara:

See the gist on github.

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:

See the gist on github.

Ordenando arreglo de manera ascendente

El código completo para ordenar un arreglo de manera ascendente en C usando qsort es:

See the gist on github.

Con la siguiente salida:

Imprimir arreglo sin ordenar, después ordenarlo con qsort e imprimir el arreglo ya ordenado de manera ascendente

Si quieres puedes probarlo aquí.

Ordenar arreglo de manera descendente

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í:

See the gist on github.

De manera que el código completo es el siguiente:

See the gist on github.

Al ejecutarlo se obtiene:

Arreglo descendente en C

Lo que puedes probar aquí.

Conclusión

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í.

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

No te pierdas ninguno de mis posts

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Compartir
Publicado por
parzibyte

Entradas recientes

Solución: Unable to extract uploader id con youtube-dl

En mi blog te he enseñado a usar youtube-dl para descargar vídeos con permiso del…

15 horas hace

Enviar foto a Telegram usando cURL y Bot

Siguiendo con los tutoriales que consumen la API de los Bots de Telegram con cURL…

15 horas hace

cURL y Telegram: enviar mensaje a Bot

En un post previo te enseñé a enviar un mensaje en nombre de un Bot…

18 horas hace

Impresora térmica con Telegram usando Bot

En este artículo te voy a mostrar una guía para imprimir en una impresora térmica…

22 horas hace

Imprimir PDF con Bot de Telegram

La impresión de un PDF en cualquier impresora se puede automatizar con un bot de…

5 días hace

Enviar mensaje con bot de Telegram usando JavaScript (lado del cliente)

Hoy te enseñaré cómo enviar un mensaje a un usuario desde un bot de Telegram…

6 días hace

Esta web usa cookies.