Hola a todos!
Y hoy con ganas de trabajar con números primos! De hecho he decido crear una función que nos permita generar los números primos que se encuentran dentro del rango de dos cifras, por ejemplo del 2 al 100.
Hace ya tiempo creé un post relacionado que generar los n primeros números primos, pero era necesario ampliar el post y hacer de modo que podamos extraer a partir de un rango.
Como siempre, es una custom function y creo que os resultará muy sencilla porque está bastante comentado el código:
/**
* @customfunction
* @param {number[][]}
* @returns {number[][] }
*/
function numPrimEntre(min, max) {
var primos: number[] = [];
// Comenzamos en dos aunque el primer número sea menor que 2
if (min < 2) { min = 2;
}
// recorremos todos los números
for (var num = min; num <= max; num++) {
var esPrimo = true;
// verificamos si es número
for (var i = 2; i < num; i++) {
if (num % i === 0) {
esPrimo = false;
break;
}
}
// si es correcto lo incluimos en el array
if (esPrimo) {
primos.push(num);
}
}
//pasamos resultado a la función
return [primos];
}
Cuando aplicamos la función (y utilizaremos también la función transponer de Excel para expresar los datos en vertical), este es el resultado:

Como podéis observar, la función ha extraído todos los números primos incluidos en el rango. Y esto es todo, espero que sea de utilidad 🙂
¿Te ha resultado de interés?, puedes apoyar a Excel Signum con una pequeña donación.
¡¡Muchas gracias!!
Mediante la suscripción al blog, la realización comentarios o el uso del formulario de contacto estás dando tu consentimiento expreso al tratamiento de los datos personales proporcionados según lo dispuesto en la ley vigente (LOPD). Tienes más información al respecto en esta página del blog: Política de Privacidad y Cookies