用filter()筛选出素数
题目出自廖雪峰老师的 教程:
请尝试用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());
运行结果:
测试通过!
继续阅读与本文标签相同的文章
上一篇 :
神一般的存在!创业好物,了解一下?
下一篇 :
js对数组的操作
-
猎户星空CEO傅盛:现在是AI发展最好时期,家庭服务机器人前景可期
2026-05-14栏目: 教程
-
5G远程驾驶和微公交首秀互联网大会
2026-05-14栏目: 教程
-
学宏程序编程,这些知识必不可少!
2026-05-14栏目: 教程
-
华为准备卖出“落后”的5G,多家美企极力竞争!任正非格局太大!
2026-05-14栏目: 教程
-
百度:飞桨深度学习平台已累计服务150多万开发者
2026-05-14栏目: 教程
