1. 程式人生 > >用filter()篩選出素數

用filter()篩選出素數

用filter()篩選出素數

題目出自廖雪峰老師的JavaScript教程:
請嘗試用filter()篩選出素數:

'use strict';
function get_primes(arr) {
    function isPrimeNumber(x) {
        if(x===1) {
            return false;//1不是素數,返回false
        }
        //i是2到x開平方根之間的整數
        //如果x對i取餘等於0,則不是素數,返回false
        for(let i=2;i<=Math.sqrt
(x,2);i++) { if(x%i===0) { return false; } } //如果上述條件都不滿足,則是素數,返回true return true; } //用filter()返回新的只含有素數的陣列 return arr.filter(isPrimeNumber); }

我們用以下程式碼來測試一下:

// 以下程式碼用於測試:
var
    x,
    r,
    arr = [];
for (x = 1; x < 100
; x++) { arr.push(x); } r = get_primes(arr); if (r.toString() === [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97].toString()) { console.log('測試通過!'); } else { console.log('測試失敗: ' + r.toString());

執行結果:

測試通過!