Saltar al contenido
Portada » Algoritmo Naive o Ingenuo

Algoritmo Naive o Ingenuo

El algoritmo naive o ingenuo en la detección de patrones es uno de los más fundamentales, con una complejidad computacional de O(n2). Los algoritmos de detección de patrones pretenden encontrar una cadena en un texto, extrayendo cual es su posición.

Implementación en Java

 
public class BusquedaNaive {
 
    static void busqueda(String patron, String texto)
    {
        int limitePatron = patron.length();
        int limiteTexto = texto.length();
        int i = 0, j = limiteTexto - 1;
 
        for (i = 0, j = limiteTexto  - 1; j < limitePatron;) {
 
            if (texto.equals(patron.substring(i, j + 1))) {
                System.out.println("Patron encontrado en el indice "
                                   + i);
            }
            i++;
            j++;
        }
    }
 
    public static void main(String args[])
    {
        String patron = "AABAACAADAABAA";
        String texto = "AADA";
     
        busqueda(patron, texto);
    }
}

Más algoritmos de búsqueda y ordenación

AsuntoDescripción
Ordenación BurbujaOrdenación algoritmo BubbleSort.
Ordenación InserciónAlgoritmo de ordenación por inserción
Ordenación SelecciónAlgoritmo de ordenación por selección
Ordenación QuicksortAlgoritmo de ordenación eficiente Quicksort
Búsqueda BinariaAlgoritmo de búsqueda binaria
Patrones: Algoritmo ZDetección de patrones con algoritmo Z
Patrones: Algoritmo NaiveDetectar patrones con algoritmo ingenuo o naive
Algoritmo de Dijkstra Como encontrar el camino más corto entre dos nodos en un grafo ponderado
Algoritmo de KruskalSe utiliza para encontrar el árbol de expansión mínimo en un grafo ponderado

Recursos básicos Java

AsuntoDescripción
Tutorial básico y sintaxisTutorial básico Java y sintaxis. Aprende los fundamentos del lenguaje.
Hilos (Threads)Aprende a manejar hilos y las cuestiones básicas de la concurrencia
Funciones LambdaAquí te enseñamos las nociones más importantes para arrancas con funciones lambda
PalíndromosPrograma de ejemplo para el uso de palíndromos en Java.
Máquina Virtual de JavaTe explicamos el funcionamiento de la máquina virtual de java (Java Virtual Machine – JVM)
JDK, JRE y JVMDiferencias entre el JDK, JRE y JVM.
Mejores libros Java en EspañolHazte con los mejores libros Java para aprender paso a paso y profundizar en las mejores prácticas
TensorFlowManejo del API de TensorFlow para la construcción de grafos de operaciones y su ejecución
Tutorial Log4jTutorial para el manejo de Log4j, herramienta ágil y flexible para la gestión de Logs en Java
Java SecurityEntiende y aplica las posibilidades que da Java para mantener la seguridad
Tutorial JConsoleAprende los conceptos básicos de monitorización de procesos Java con JConsole
JavaFXTutorial de JavaFX, librería gráfica moderna para construcción de GUIs en móvil, escritorio y web.
Estructuras de datos en JavaExplicación y ejemplos de las estructuras de datos más importantes: listas, pila, cola, arbol.
JavaapiConjunto de clases, interfaces, métodos y paquetes que forman parte de la plataforma Java estándar
Algoritmo HuffmanMétodo eficiente para codificar datos, asignando códigos más cortos a los caracteres más frecuentes