Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube
JC Mouse Bolivia
Index / Java / Búsqueda binaria (Binary Search)

Búsqueda binaria (Binary Search)

Autor jc mouse jueves, marzo 3, 2016

Un algoritmo de búsqueda binaria se emplea para buscar un valor en particular en un arreglo previamente ordenado. Para implementar este algoritmo se compara el elemento a buscar con un elemento cualquiera del array (normalmente el elemento central) si el valor de éste es mayor que el del elemento buscado se repite el procedimiento en la parte del array que va desde el inicio de éste hasta el elemento tomado, en caso contrario se toma la parte del array que va desde el elemento tomado hasta el final. De esta manera obtenemos intervalos cada vez más pequeños, hasta que se obtenga un intervalo indivisible. Si el elemento no se encuentra dentro de este último entonces se deduce que el elemento buscado no se encuentra en todo el array. Es decir  “Divide y Conquista”

Por ejemplo en un array de números enteros de 19 elementos, previamente ordenado, queremos buscar el número 47, entonces partiríamos de:

binary search

Lo primero que hacemos es dividir el array en 2 y preguntar si el numero del medio es igual, mayor o menor que el número buscado, si es igual, la búsqueda termina. En nuestro ejemplo es mayor por lo que nos olvidamos de la primera mitad, sabemos que el numero que buscamos no esta ahí.

busqueda binaria

Volvemos a dividir el array restante en dos y realizamos la misma pregunta. En esta ocasión el 47 esta en la primera mitad.

java binary

Dividimos una vez más y el array y este continua reduciéndose.

binario netbeans

Finalmente nos quedo un array con solo un elemento, realizamos la misma pregunta y encontramos el número que buscábamos, el 47. La búsqueda termina con solo 4 iteraciones.

binario

Si realizáramos una búsqueda secuencial, es decir: posición 1, posición 2, posición 3, posición 4,etc hasta llegar a la posición que ocupa el numero 47, la misma búsqueda nos hubiera llevado 11 iteraciones.

El algoritmo de búsqueda binaria es sencillo y pequeño, pero a la vez para un programador novato un poco abstracto, por lo que creo es mucho mejor para el aprendizaje, ver el funcionamiento del algoritmo de búsqueda en acción.

El programa de búsqueda (código fuente) mostrado en el video de arriba puede descargarlo gratis a continuación:

<<ENLACE POBRE “Búsqueda Binaria”>>

El código se encuentra comentado 🙂 pero ante cualquier duda, abajo esta la sección de comentarios.

IDE: Netbeans 8 java 8

enjoy!!!

Tags

Si te ha gustado podrías compartirlo o dejar un comentario. ¡Muchas gracias!
Autor: JC Mouse

Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.

Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye

Enjoy! :)

También Te Podría Interesar

Formulario de login personalizado

Formulario de login personalizado

Hola, en este oportunidad dejo a disposición un formulario de logueo que se me ocurrió de repente creo inspirado en las...

Decompilar archivos APK

Decompilar archivos APK

Las aplicaciones para celulares inteligentes con sistema operativo Android, se distribuyen en archivos *.APK, si como pr...

Introducción a VueJS framework para el desarrollo FrontEnd

Introducción a VueJS framework para el desarrollo FrontEnd

Vue.js es un framework progresivo para la creación de interfaces de usuario de una sola página creado por Evan You. Pero...

“Hola Mundo” en kotlin con Eclipse

“Hola Mundo” en kotlin con Eclipse

Kotlin es un lenguaje de programación de tipado estático que corre sobre la máquina virtual de Java y que también puede...

Gráfico de lineas con jfreechart

Gráfico de lineas con jfreechart

Los gráficos de líneas muestran una serie como un conjunto de puntos conectados mediante una línea. Los valores se repre...

Crea patrón de desbloqueo para tus app java

Crea patrón de desbloqueo para tus app java

El patrón de desbloqueo es una medida de seguridad que tienen algunos teléfonos inteligentes para evitar el acceso al di...

Comparte lo que sabes

Categorias

Últimas entradas

MyBatis es un framework de persistencia Java que se encarga de mapear sentencias SQL y procedimientos almacenados a part...

Webcam Capture es un API  que permite usar una cámara web incorporada o externa directamente desde código Java utilizand...

im4java es una interfaz pura de Java para la línea de comandos de ImageMagick. La interfaz de la línea de comandos de IM...

En un post anterior conocimos una herramienta Open Source con un conjunto de herramientas para el trabajo con imágenes e...

Herramientas

Generador de Enlaces a Whatsapp