js小题狂练(3)-筛素数
2018-02-16 14:49
162 查看
选自廖雪峰js教程
请尝试用
// 测试:
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;
});
}
请尝试用
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;
});
}
相关文章推荐
- JS学习笔记2——利用filter()去除数组中的重复元素,利用filter()筛选出数组中的素数
- 算法小题2→素数
- js小题
- JS 筛选出1-100间的素数
- js 正则之检测素数
- 牛客小题(js)
- JS 用6N±1法求素数 实例教程
- js小题狂练(2)-用户英文名规范
- js的一个有意思的小题,闭包解决getElementByTagName的for循环绑定事件错误问题
- 一些js小题(一)
- js 正则之 检测素数
- 一些js小题(一)
- 求小于某数的素数,JS
- js: 输出一个数以内的素数
- js一些小题(二)
- 常让人误解的一道js小题
- js一些小题(二)
- js小题狂练(1)-map+reduce字符串转整型
- js打印出1-10000之间的所有素数
- js算法判断是否为素数