选自廖雪峰js教程
请尝试用filter()
筛选出素数:
// 测试: 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()); }
相对快一点点的解法吧233
'use strict'
function get_primes(arr)
{
return arr.filter(function(val,index,self){
if(val==1) return false;
if(val==2) return true;
for(var i=2;i<=Math.sqrt(val);i++)
if(val%i==0)
return false;
return true;
});
}