在數學中,素數是大於1 的整數,除了1 和它們本身之外,不能被任何其他數字整除。尋找特定範圍內的質數可能是常見的程式設計任務。以下是如何在 JavaScript 中解決此問題的詳細說明:
提供的程式碼片段嘗試使用暴力方法來尋找 0 到 100 之間的素數。它檢查該數字是否可以被 2 到 12 之間的任何數字整除,如果找不到約數則傳回該數字。然而,這種方法有幾個缺點:
一種更有效的查找素數的演算法稱為埃拉托斯特尼篩法。它的工作原理如下:
在JavaScript 中,程式碼為埃拉托斯特尼篩法看起來像這樣:
<code class="js">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; }</code>
這種方法的時間複雜度為O(n log log n),比蠻力方法有效率得多。
以上是如何有效地找到給定範圍內的質數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!