JS 用6N±1法求素数 实例教程

 更新时间:2009年10月20日 15:23:26   作者:  
显然,当N≥1时,6N,6N+2,6N+3,6N+4都不是素数,只有形如6N+1和6N+5的自然数有可能是素数。所以,除了2和3之外,所有的素数都可以表示成6N±1的形式(N为自然数)。
用6N±1法求素数
任何一个自然数,总可以表示成为如下的形式之一:
6N,6N+1,6N+2,6N+3,6N+4,6N+5 (N=0,1,2,…)
显然,当N≥1时,6N,6N+2,6N+3,6N+4都不是素数,只有形如6N+1和6N+5的自然数有可能是素数。所以,除了2和3之外,所有的素数都可以表示成6N±1的形式(N为自然数)。
根据上述分析,我们可以构造另一面筛子,只对形如6 N±1的自然数进行筛选,这样就可以大大减少筛选的次数,从而进一步提高程序的运行效率和速度。
以下代码需要自然数大于10
复制代码 代码如下:

function fn(num){
var arr = [];
arr.push(2);
arr.push(3);
arr.push(5);
arr.push(7);
var t = 0;
for (var i = 3; t < num; i = i + 3) {
for (var j = 0; j < 2; j++) {
t = 2 * (i + j) - 1;
if (t < num && (t % 5 == 0 ? false : t % 7 == 0 ? false : true)) {
arr.push(t);
}
}
}
return arr.join(” “);
}
document.write(fn(1000));

各位大侠有没有更高效的方法或以上代码有不对的地方,请指出。

相关文章

  • js处理跨域的方案之jsonp用法详解

    js处理跨域的方案之jsonp用法详解

    这篇文章主要介绍了js处理跨域的方案之jsonp用法的相关资料,文中分享了前端调用后端接口的三种方式:Ajax、fetch、axios,并详细解释了同源策略和跨域的概念,需要的朋友可以参考下
    2024-11-11
  • JS保留两位小数,多位小数的示例代码

    JS保留两位小数,多位小数的示例代码

    本篇文章主要是对JS保留两位小数,多位小数的示例代码进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • js clearInterval()方法的定义和用法

    js clearInterval()方法的定义和用法

    clearInterval()方法能够取消setInterval()方法设置的定时器,本文给大家详解clearInterval()方法的定义和用法,感兴趣的朋友参考下。
    2015-11-11
  • bootstrap table插件动态加载表头

    bootstrap table插件动态加载表头

    这篇文章主要为大家详细介绍了bootstrap table插件动态加载表头,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • 前端如何解决滚动穿透问题详解

    前端如何解决滚动穿透问题详解

    这篇文章主要介绍了前端解决滚动穿透问题的五种常见方法,并详细分析了它们的优缺点和适用场景,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-03-03
  • iframe src为图片时的高度自适应的代码

    iframe src为图片时的高度自适应的代码

    iframe src为图片时的高度自适应的代码...
    2007-10-10
  • javascript数据结构之二叉搜索树实现方法

    javascript数据结构之二叉搜索树实现方法

    这篇文章主要介绍了javascript数据结构之二叉搜索树实现方法,较为详细的分析了二叉搜索树的概念、原理与JavaScript实现二叉搜索树的方法,对于学习JavaScript数据结构具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • 详解堆的javascript实现方法

    详解堆的javascript实现方法

    最近因为工作需要,要深入的学习JavaScript,发现如果囫囵吞枣印象就是不深刻,自己去练习一下才能慢慢有点感觉。本文主要是详解堆的javascript实现方法,另外堆排序对我们来说太耳熟而又少用的情况下,本文当作一次复习。感兴趣的朋友们下面来一起看看吧。
    2016-11-11
  • js根据日期判断星座的示例代码

    js根据日期判断星座的示例代码

    本篇文章主要是对js根据日期判断星座的示例代码进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • ES6中Array.includes()函数的用法

    ES6中Array.includes()函数的用法

    这篇文章主要介绍了ES6中Array.includes()函数的用法,需要的朋友可以参考下
    2017-09-09

最新评论