我想要一個名爲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