Lenguaje de programación C

Programa en C: búsqueda binaria recursiva y secuencial en arreglos

Introducción

Luego de algún tiempo he terminado de implementar la función recursiva y con ciclos para ejecutar el algoritmo de búsqueda binaria en un arreglo numérico en C.

Este algoritmo también es conocido como divide y vencerás; pues va dividiendo el arreglo en 2 hasta encontrar lo que buscamos, aunque como requisito dicho arreglo debe estar ordenado.

Explicación del algoritmo

Toma el elemento del medio del arreglo usando la función floor para redondear, lo compara con lo que buscamos y si coincide entonces regresa el índice.

En caso de que no, compara si lo que buscamos está a la izquierda o derecha del medio, y a partir de ello parte el arreglo desde la izquierda hasta la mitad, o desde la mitad hasta la derecha y así hasta terminar.

Para una más detallada, visita esta página en donde además podrás ver otras implementaciones en otros lenguajes.

Búsqueda binaria en C con recursión

La primera función que veremos es la que aplica recursión o recursividad:

See the gist on github.

La condición de salida varía: la primera es que se encuentre el elemento, ahí se regresa el índice en donde se encuentra lo que buscamos.

La segunda es cuando ya dividimos tantas veces y no encontramos nada, así que regresamos -1.

Para probar este algoritmo sigue bajando, dejaré todo eso hasta abajo.

Búsqueda binaria en C con ciclo while

Nota sobre la longitud del arreglo: en otros lenguajes, podríamos saber la longitud del arreglo que nos pasan. En C no es así porque cuando pasamos un arreglo como parámetro a una función, se convierte en puntero.

Podemos calcularla en el ámbito en donde se declara, esto es justo cuando llamamos a la función. Igual más abajo veremos cómo se hace; mientras tanto así es la función:

See the gist on github.

Es lo mismo, pues vamos cambiando los valores de derecha e izquierda; partiendo así el arreglo. En caso de encontrar lo que buscamos se regresa el índice; y si no (esto es cuando el ciclo termina) entonces -1.

Implementación de búsqueda binaria en C

Con este código podemos probar todo lo explicado arriba:

See the gist on github.

También puedes probarlo y ejecutarlo directamente en el navegador.

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/

Ver comentarios

Entradas recientes

JavaScript (lado del cliente): leer pixeles de imagen

En ocasiones es necesario leer los pixeles y colores de una imagen con JavaScript del…

5 días hace

PHP y JavaScript: llenar select con AJAX

Siguiendo con los tutoriales de listas desplegables o select con JavaScript, vamos a ver cómo…

5 días hace

Imprimir PDF generado con HTML

Hoy vamos a ver programar la impresión de un PDF generado a partir de HTML…

6 días hace

JavaScript: llenar select con arreglo

En este tutorial básico de JavaScript con HTML vamos a ver cómo llenar una lista…

2 semanas hace

Imprimir PDF a partir de URL

En este artículo se presenta una guía para imprimir un PDF a partir de una…

2 semanas hace

Imprimir PDF a partir de base64

En este post voy a enseñarte cómo imprimir un PDF a partir de su representación…

2 semanas hace

Esta web usa cookies.