Beruflich Dokumente
Kultur Dokumente
y Complejidad
Adaptacin
Programacin Avanzada
Prim. 2009
ndice
Complejidad Computacional
Algoritmos de Ordenamiento simples
Burbuja
Insercin
Seleccin
Complejidad Computacional
Definicin: Mide la eficiencia de un algoritmo en
trminos de tiempo o espacio requeridos.
El Tiempo tiende a ser ms importante.
La eficiencia de un algoritmo siempre se establece
como una funcin del tamao de la entrada.
La notacin Big-O o O(f(n))
Funciones Bsicas de la
Complejidad del Tiempo
En un orden creciente de complejidad:
Funciones Bsicas de la
Complejidad del Tiempo
Insercin (InsertionSort)
Algoritmo*:
Inicia con el primer elemento de la entrada
Itera sobre el arreglo de entrada hasta que est vaco, eliminando el
elemento restante de ms a la izquierda.
Compara el elemento removido con el elemento actual,iniciando
desde el elemento ms alto, y comparando hacia la izquierda, hasta el
elemento menor
Si el elemento de entrada eliminado es menor que el elemento actual,
copia el valor a un temporal para hacer espacio al nuevo elemento
menor y repite esto con cada elemento que resulte menor.
De otra forma, el nuevo elemento esta en la posicin correcta;
almancnalo en la localidad a la izquierda e inicia nuevamente desde
el paso 2 con el siguiente elemento de entrada.
Complejidad: O(n2)
Demo:
http://web.engr.oregonstate.edu/~minoura/cs162/javaProgs/sort/
Ejemplo: Ordena la lista {12, 5, 7, 9, 2, 6}
8
Complejidad: O(n2)
Demo:
http://web.engr.oregonstate.edu/~minoura/cs162/javaProgs/sort/
QuickSort
Bsqueda
Demos y Cdigo Fuente:
http://web.engr.oregonstate.edu/~minoura
/cs162/javaProgs/search/
11
Preguntas?
12