Daftar Isi:
2025 Pengarang: John Day | [email protected]. Terakhir diubah: 2025-01-23 14:49
En el mundo de las ciencias de la computación, saber ordenar listas es como saber escribir. Es una buena manera de ver como los algoritmos son una manera de hacer las cosas en una computadora, y que la forma directa de hacer algo no es la mejor en una computadora. Acá explico uno de los algoritmos más cnocidos de comutación que es el "Bubble Sort", y explicaré con detalle en que terdiri
Este Instructable, mempertimbangkan que es AVANZADO, pero no hay nada como los retos difíciles, así que si no eres experto o experta no importa, haz el intento igual…
Langkah 1: Daftar Ordenar?
Hoy en día usamos la computadora en todas las cosas. Los teléfonos hoy en día son prácticamente super computadoras. Mientras las computadoras toman datos, se construyen listas de datos. Una lista de datos es un conjunto de datos como este:
{Tomás, Abraham Carolina, Matias, Maria, Marcela}
Es una lista de nombres. Ahora bien, en muchas ocasiones, necesitamos ordenarlos, es decir acomodar la lista en un orden khususnya, por ejemplo de mayor a menor atau sebaliknya, o en orden alfabético.
Porque ordenarlos? Veamos el ejemplo de la lista de nombres de la imagen. Es una lista larga, si les pido busquen el nombre IRENE, en cual lista es más fácil? en la ordenada verdad? bueno por eso mismo ordenar listas de datos es algo extremadamente importante en una computadora, pera luego poder usar los datos de forma efectiva.
Como los ordeno? pasemos al siguiente paso
Langkah 2: Algoritma "Urutan Gelembung" Ordenamiento De Burbuja
Si tengo una lista de números, o nombres, Cómo las puedo ordenar? Existen muchas maneras de hacerlo, acá les voy a explicar la que se llama "Bubble Sort", no es de las más rápidas, de hecho puede que sea de las peores, pero si es un buen ejemplo de como una ide se escribe como un algoritme, y luego se escribe como un programa de computadora. Además, taman bermain sirkuit creo que ve super bonito en el.
La Ide
La idea del Bubble Sort, es la de burbujas flotando, si ha dos burbujas y una es más grande que la otra, la más liviana pasa a la más pesada, y así se van acomodando… es de muy a tener una caja de piedras diferentes tamaños, si las sacudo por suficiente tiempo, las más pesadas se van al fondo y las livianas se quedan arriba.
El Algoritma
Los pasos del algoritmos putra:
- Tenemos una lista de 1 a n elementos
- Komentar untuk el 1
- Preguntar si el número en la posición actual es mayor que el de la posición siguiente
- Si es mayor cambiarlos, sino, dejarlos igual
- Penggerak tanpa posisi
- Si es el n, mengaktifkan marcar n-1 cómo el ltimo y volver a 2
- Sino, Volver a 3
- Si el marcado como ltimo es igual al primero, mengaktifkan terminal
En Accion
Como ven a veces escribir un algoritmo es algo confuso, por eso vean el video explico cual es el concepto y funcionamiento detrás del algoritmo con un ejemplo sencillo.
Langkah 3: El Algoritmo En El Circuit Playground
El Código dasar
Veamos primero una versión del algoritmo, sin agregarla nada de luces o sonido:
angka byte[9];//Arreglo que contiene los numeros
int i, j;//Iteradores
//Algoritma bubbleSort
void loop() { for (i = 0; i <= 9; i++) { for (j = 0; j <= 9 - i; j++) { if (angka[j] <= angka[j + 1]) { //cambia posición de números float f = angka[j]; angka[j] = angka[j + 1]; angka[j + 1] = f; } } } }
Como ven primero creamos un arreglo de byte, en este caso lo llamamos number[9]. Es un arreglo de 10 números (de 0 a 9), de numero tipo byte. Tambi'en creamos dos iteradores i y j. Estos son los que vana recorrer el arreglo.
En el loop prinsipal, vean las línea:
untuk (i = 0; i <= 9; i++){ untuk (j = 0; j <= 9 - i; j++) { } }
Que i recorre todo el arreglo de 0 a 9. Dentro de esta j, note como va de 0 a 9-i. Es decir, primero va de 0 a 9, luego de 0 a 9-1, luego de 0 a 9-2. Esto porque como se ve en el video, por cada iteración sabemos que el ultimo numero ya es el mayor.
Dentro de esos iteradores, se hace la pregunta:
if (angka[j] <= angka[j + 1])
Es decir si el siguiente es menor o igual entonces debemos cambiarlo. Untuk cambiarlo hay que hacer un "swap" es decir tomar el valor del arreglo, guardarlo en una variable temporal, asignárle el nuevo valor, y luego en temporal al la siguiente posición del arreglo. Vánlo en estas trés líneas de código:
float f = angka[j]; //sementara
angka[j] = angka[j + 1]; angka[j + 1] = f;
Descargar el Circuit Playground
Lengkapi Github, termasuk untuk melakukan hal-hal yang diperlukan untuk umum dan lengkap untuk 0 a 255, y untuk pengguna dengan jumlah besar dan lengkap, untuk prender los LED. Ustedes lo pueden modificar para que haga más cosas como sonidos, dll.
Langkah 4: Funcionando Y Reto
En el video además le agregué sonido, eso se los dejo de reto a ustedes.
Reto
- Agregar sonido
- Programar otros algoritmos de ordenamiento (Penyortiran Cepat, Pengurutan Gabung)
- Medir que tan rápido resuelve e arduino, colocando cada vez más elementos en el arreglo y medir cuanto tarda, Es lineal?
Direkomendasikan:
DIY Cara Mengontrol Sudut Motor Servo Menggunakan Komponen Urutan Visuino: 10 Langkah
DIY Cara Mengontrol Sudut Motor Servo Menggunakan Komponen Urutan Visuino: Dalam tutorial ini kita akan menggunakan Motor Servo dan Arduino UNO, dan Visuino untuk mengontrol Sudut motor servo menggunakan komponen urutan. Komponen urutan sangat cocok untuk situasi di mana kita ingin memicu beberapa peristiwa secara berurutan dalam kasus kami tingkat motor servo
Kit Ciencia Y Arte: Taman Bermain Cómo Cargar Código Al: 4 Langkah
Kit Ciencia Y Arte: Cómo Cargar Código Al Taman Bermain: Acá explicamos como se "sube" el código. EL código de cada proyecto está en cada dapat diinstruksikan, sin embargo puede descargar todo el código en el GitHub
Kit Ciencia Y Arte: Máquinas Que Aprenden Sonido: 4 Langkah
Kit Ciencia Y Arte: Máquinas Que Aprenden Sonido: Aprender de inteligencia artificial es mucho más fácil de lo que parece. El primer paso es entender el funcionamiento de una de las unidades más simples en programación, que por analogía con el cerebro humano, es l
Kit Ciencia Y Arte: Algoritmo Genetico (Vida Buatan): 6 Langkah
Kit Ciencia Y Arte: Algoritmo Genético (Vida Artificial): Los algoritmos genéticos sonprobablemente una de las cosas m's interesantes de la computaci&n (en mi opinión). Básicamente se toma la idea de evolución de la biolog&a, y se aplica a un algoritmo en u
Kit Ciencia Y Arte: Un Makey Makey a Otro Nivel: 4 Langkah (dengan Gambar)
Kit Ciencia Y Arte: Un Makey Makey a Otro Nivel: El Makey Makey es un dispositivo electrónico muy popular en educación, pues con el se pueden hacer rápidamente ejercicios de computación nyata dan interaksi con computadoras.El Makey Makey, no es m