Naps Tecnología y educación

Algoritmo de Cuadrados Medios para la generación de números Pseudoaleatorios: Implementación en Java

Veremos el Algoritmo de Cuadrados Medios y cómo implementarlo utilizando el lenguaje de programación Java.

Aprende a implementar en Java el algoritmo de cuadrados medios

Números pseudoaletarios vs números genuinamente aleatorios

Un número pseudo aleatorio es un número que cumple las funciones de un número aleatorio pero es generado a través de un algoritmo matemático. Si conocemos el algoritmo que se utilizó para generar una secuencia de números pseudo aleatorios, así como algunos valores iniciales, se puede predecir toda la secuencia de números que se van a generar.  Por  el contrario, es imposible predecir el valor siguiente de una secuencia de números genuinamente aleatorios. (Turquía, 2013).

Algoritmos para la generación de números pseudo aleatorios

Existen varios algoritmos, entre los que se cuentan: Algoritmo de cuadrados medios, algoritmos de productos medios, algoritmo de multiplicador constante, algoritmo lineal, algoritmo congruencia multiplicativo, algoritmo congruencia aditivo, algoritmos congruencia les no lineales.

En el presente artículo se analizará el algoritmo de cuadrados medios y se implementará en el lenguaje de programación Java.

Algoritmo de cuadrados medios

  1. Se elige como valor semilla un número de más de 3 dígitos (t=cantidad de dígitos del valor semilla)
  2. Se eleva ese número al cuadrado.
  3. Al valor que resultó, seleccione los t dígitos de en medio (si se requiere, utilice un 0 como primer dígito).
  4. Repetir desde el paso número 2 tomando éste nuevo número.

Implementación Java

Scanner entrada = new Scanner(System.in);
String semilla, snumero2, snumero3;
int tam1, tam2,  i, primerc;
long numero1, numero2;
        
System.out.println("Escriba semilla: ");
semilla = entrada.next();
tam1 = semilla.length();
System.out.println("Cantidad de digitos:  " + tam1);
numero1 = Integer.parseInt(semilla);
for (i=1; i<=10; i++){
      numero2 = (long)Math.pow(numero1,2);
      snumero2 = Long.toString(numero2);
      tam2 = snumero2.length();
      primerc = (tam2-tam1) / 2;
      snumero3 = snumero2.substring(primerc,primerc+tam1);
      System.out.println(i + ". " + snumero3);
      numero1 = Integer.parseInt(snumero3);
}

 

Explicación del programa

Variables

El programa utiliza las siguientes variables:

Explicación

 

Ejecución del programa

Algoritmo de cuadrados medios implementado en Java

Si deseas que aparezcan en formato decimal entre 0 y 1, puedes utilizar estas instrucciones:

numeror = Double.parseDouble(“.”+snumero3);

System.out.println(i + “. ” + snumero3 + “(” + numeror + “)”);

 

Este algoritmo nos muestra una forma de generar números pseudo aleatorios en Java. Los números pseudo aleatorios son una parte importante en la elaboración de modelos de simulación.

Si deseas ver éste algoritmo implementado en Python,  puedes consultarlo aquí: Algoritmo de Cuadrados Medios en Python para la generación de números pseudoaleatorios.

Bibliografía

  1. Coss(1996) Simulación, un enfoque práctico. Ed. Limusa.
  2. Turquía Moraleja (2013). Modelado y simulación de eventos discretos. Editorial UNED.

 

¿Qué te pareció este artículo?
  • Poco informativo ()
  • No era lo que buscaba ()
  • Regular ()
  • Interesante ()
  • Excelente ()
(Visto 38.952 veces)

Tu comentario

opiniones