Siguiendo con los tutoriales de números aleatorios en C hoy vamos a ver cómo elegir un elemento aleatorio de un arreglo en C.
Recuerda que ya hablamos sobre los arreglos en C y sobre los arreglos de cadenas en C.
Veremos cómo calcular un índice aleatorio para escoger un elemento aleatorio de un arreglo, usando las funciones que vimos al generar números aleatorios en C.
Elegir elemento aleatorio de arreglo
Para ello primero hay que saber la longitud del arreglo. Podemos definirla nosotros mismos o calcularla en tiempo de ejecución. Una vez que la tengamos, necesitamos la función que da un número aleatorio en un rango.
A partir de eso, obtenemos un número aleatorio entre 0 y la longitud del arreglo menos 1; y elegimos el elemento que esté en ese índice:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
// Devuelve un número aleatorio en un rango
int aleatorio_en_rango(int minimo, int maximo) {
return minimo + rand() / (RAND_MAX / (maximo - minimo + 1) + 1);
}
int main(void) {
// seed rand
srand(getpid());
int arreglo[] = {57, 84, 62, 486, 22, 19, 800};
// Si quieres calcularla mira:
// https://parzibyte.me/blog/2018/09/21/longitud-de-un-arreglo-en-c/
int longitudArreglo = 7;
// Obtener un índice en un rango
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
printf("Elemento aleatorio: %d\n",
arreglo[aleatorio_en_rango(0, longitudArreglo - 1)]);
return 0;
}
Como vemos, el algoritmo es sencillo. Simplemente hay que obtener un número aleatorio dentro del rango de la longitud del arreglo y usarlo como índice.
Igualmente podríamos almacenar el índice aleatorio en una variable, pero aquí estamos accediendo directamente.
Te invito a ver más sobre C aquí.