首頁  >  文章  >  web前端  >  如何在 JavaScript 中有效率地找出某個範圍內的質數?

如何在 JavaScript 中有效率地找出某個範圍內的質數?

Patricia Arquette
Patricia Arquette原創
2024-10-30 22:49:30355瀏覽

How to Efficiently Find Prime Numbers Within a Range in JavaScript?

高效率找出某個範圍內的素數

在 JavaScript 中,辨識指定範圍內的質數可以透過多種方法實現。常用的方法是埃拉托斯特尼篩法演算法。該技術將素數的倍數標記為非素數,從而可以有效識別素數。

以下是改進的埃拉托色尼篩法算法的JavaScript 實現,用於查找0 到100 範圍內的素數:

function getPrimes(max) {
    var sieve = [], i, j, primes = [];
    for (i = 2; i <= max; ++i) {
        if (!sieve[i]) {
            // i has not been marked -- it is prime
            primes.push(i);
            for (j = i << 1; j <= max; j += i) {
                sieve[j] = true;
            }
        }
    }
    return primes;
}

在此函數中,名為“ sieve」的陣列用於追蹤標記為非素數的數字。從 2 到指定的最大值迭代數字,未標記的數字被視為質數並添加到 'primes' 數組中。隨後,多個質數在「sieve」數組中被標記為非素數。

透過使用此函數,您可以有效地檢索指定範圍內的所有素數。例如,getPrimes(100) 將傳回 2 到 100(含)之間所有質數的陣列。

以上是如何在 JavaScript 中有效率地找出某個範圍內的質數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn