求任意自然数内的素数

作者:mike 来源:163UED 时间:2009-10-15 12:21:00 

用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));

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

标签:素数,自然数,算法
0
投稿

猜你喜欢

  • JDBC连接MySQL数据库关键的四个步骤

    2009-12-17 12:06:00
  • MYSQL各字段的长度是多少?

    2009-10-28 18:32:00
  • 在ASP中使用SQL语句之5:开始执行

    2007-08-11 12:36:00
  • asp程序运行速度测试

    2008-02-11 19:11:00
  • asp如何制作一个文本文件编辑器?

    2010-07-07 12:26:00
  • 优化你的ASP程序及优化网页

    2007-10-06 23:02:00
  • asp获取远程网页的指定内容的实现代码

    2011-02-16 10:41:00
  • WEB标准与XHTML 1.0 Transitional等文档类型介绍

    2007-10-20 21:18:00
  • OracleEXP和IMP用法和介绍

    2010-07-28 13:18:00
  • 栅格:从混乱到秩序

    2008-07-02 12:09:00
  • 交互设计:简单

    2011-08-27 16:46:27
  • asp脚本延时 自定义的delay函数

    2008-04-07 12:59:00
  • 如何在服务器端调用winzip命令行对文件压缩和解压

    2008-01-26 20:44:00
  • 嵌入式Web视频点播系统实现方法

    2007-10-10 21:17:00
  • asp如何检测HTTP表头信息?

    2010-06-28 18:20:00
  • JS实现css边框样式设置工具

    2008-05-25 16:22:00
  • Javascript的错还是浏览器的问题——2009年为何显示为109年

    2009-01-11 18:19:00
  • 在Dreamweaver MX中应用“占位图形”

    2009-07-10 13:16:00
  • 用VBS语言实现的网页计算器源代码

    2007-12-26 17:09:00
  • js实现(层,表格)元素圆角的函数

    2008-01-01 16:40:00
  • asp之家 网络编程 m.aspxhome.com