我想要一个名为findFirst的函数,它需要参数n和q,并返回除n以上的最小质数,它大于或等于q。所以,我首先写了一个函数来说明一个数是否为素数。同一件事情的两个函数,一个崩溃,另一个不崩溃,为什么?
var isPrime = function(n){
if(n === 1){
return false;
}
else if (n === 2 || n === 3){
return true;
}
else {
for(i=2; i < n; i++){
if(i * i >= n){
for(j=2; j<=i; j++){
if(n % j === 0){
return false;
}
}
return true;
}
}
}
};
还有其他的方法可以使这个效率更高,但我很肯定这个功能不是问题。
所以用这个功能我做了写的FindFirst我第一次尝试:
var findFirst = function(n,q){
var p = q;
while(n % p !== 0 || isPrime(p) === false){
p++;
}
return p;
};
此功能,但有大量崩溃,例如它崩溃输入(6310545154,3)。顺便说的6310545154的主要动力分解为2 * 3155272577
所以我写了另一个函数,将第一只列出了许多的主要因素:
var getFactors = function(n){
var factors = [];
var k = n;
var p = 2;
while(isPrime(k) === false && k !== 1){
while(k % p !== 0 || isPrime(p) === false){
p = p+1;
}
while(k % p === 0){
k = k/p;
}
factors.push(p);
}
if(isPrime(k) === true){
factors.push(k);
return factors;
}
if(k === 1){
return factors;
}
};
现在我在的FindFirst第二次尝试:
var findFirst = function(n,q){
var array = getFactors(n);
var p = 0;
for(i = 0; i < array.length; i++){
if(array[i] >= q && p === 0){
p = array[i];
}
}
return p;
};
这一个很好。它不会在上面这么大的数字上崩溃并立即计算结果。任何人都可以看到为什么会发生?看起来我最初尝试的'while'循环与getFactors函数中的'while'循环非常相似。而第二次尝试看起来更复杂。
你说什么'q'是;那么'n'呢? – cheeken
它没有崩溃它只需要很长的时间来计算,它返回'3155272577'是预期的输出? – Musa
@cheeken:你说得对,那应该说是“返回除n以上的最小素数”,它大于或等于q。我会编辑它。 – gmath