Hoy veremos cómo implementar el algoritmo de la burbuja para ordenar una lista o arreglo en Python; es decir, el código python para ordenar un arreglo con el ordenamiento de burbuja.
Recordemos que este método es más lento comparado con otros, pero que nos sirve de introducción para el ordenamiento de listas.
Nota: aquí, asumiré que “lista” y “arreglo” son lo mismo.
Se debe recorrer la lista 2 veces. Es decir, en un ciclo, recorremos la lista. Dentro de ese ciclo hacemos otro ciclo que recorre de nuevo la lista, pero solo hasta su penúltimo elemento.
Dentro del ciclo interno, comparamos el valor actual con el siguiente. Es decir, el del índice actual, con el del índice actual + 1. Si el actual es mayor, entonces intercambios actual con el siguiente.
Al final, después de los dos ciclos, el arreglo estará ordenado.
Por lo tanto podemos definir una función que recibe como argumento un arreglo, y lo ordena. Presta atención a los comentarios de la función.
Recuerda que en Python podemos intercambiar variables de manera sencilla así: a, b = b, a
También recuerda que en este caso, no necesitamos regresar el arreglo en la función, pues al modificarlo, se modifica la variable original (aunque puedes crear una copia antes por si quieres el original).
def burbuja(arreglo):
# Calculamos la longitud del arreglo para tener un código más limpio
longitud = len(arreglo)
# Recorremos todo el arreglo
for i in range(longitud):
# Dentro del ciclo, volvemos a recorrerlo. Pero ahora hasta el penúltimo elemento
for indice_actual in range(longitud - 1):
indice_siguiente_elemento = indice_actual + 1
# Si el actual es mayor que el siguiente, ...
# Nota: para un orden inverso, cambia `>` por `<`
if arreglo[indice_actual] > arreglo[indice_siguiente_elemento]:
# ... intercambiamos los elementos
arreglo[indice_siguiente_elemento], arreglo[indice_actual] = arreglo[indice_actual], arreglo[indice_siguiente_elemento]
# No hace falta regresar nada, pues el arreglo ya fue modificado
El código se explica por sí mismo. En el comentario también coloqué cómo es que puedes ordenar el arreglo de mayor a menor, pues así como está, ordena de menor a mayor.
Finalmente podemos usar la función así:
"""
https://parzibyte.me/blog
"""
def burbuja(arreglo):
# Calculamos la longitud del arreglo para tener un código más limpio
longitud = len(arreglo)
# Recorremos todo el arreglo
for i in range(longitud):
# Dentro del ciclo, volvemos a recorrerlo. Pero ahora hasta el penúltimo elemento
for indice_actual in range(longitud - 1):
indice_siguiente_elemento = indice_actual + 1
# Si el actual es mayor que el siguiente, ...
# Nota: para un orden inverso, cambia `>` por `<`
if arreglo[indice_actual] > arreglo[indice_siguiente_elemento]:
# ... intercambiamos los elementos
arreglo[indice_siguiente_elemento], arreglo[indice_actual] = arreglo[indice_actual], arreglo[indice_siguiente_elemento]
# No hace falta regresar nada, pues el arreglo ya fue modificado
# Modo de uso.
mi_arreglo = [3, 4, 1, 2, 3, 7, 55, 34, 43, 3]
print("Original: ")
print(mi_arreglo)
burbuja(mi_arreglo)
print("Ordenado: ")
print(mi_arreglo)
La salida en este caso es:
También puedes leer más sobre Python en mi blog.
El día de hoy te mostraré cómo crear un servidor HTTP (servidor web) en Android…
En este post te voy a enseñar a designar una carpeta para imprimir todos los…
En este artículo te voy a enseñar la guía para imprimir en una impresora térmica…
Hoy te voy a mostrar un ejemplo de programación para agregar un módulo de tasa…
Los usuarios del plugin para impresoras térmicas pueden contratar licencias, y en ocasiones me han…
Hoy voy a enseñarte cómo imprimir el € en una impresora térmica. Vamos a ver…
Esta web usa cookies.