免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234下一页
最近访问板块 发新帖
查看: 17274 | 回复: 37
打印 上一主题 下一主题

[C] 求2~2000的所有素数.有足够的内存,要求尽量快 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-09-20 20:16 |只看该作者 |倒序浏览
求2~2000的所有素数.有足够的内存,要求尽量快

答案:
int findvalue[2000]={2};
static int find=1;
bool adjust(int value)
{
assert(value>=2);
if(value==2) return true;
for(int i=0;i<=find;i++)
{
if(value%findvalue==0)
return false;
}
findvalue[find++];
return true;
}

没看明白,谁给讲讲,3ks!

论坛徽章:
0
2 [报告]
发表于 2008-09-20 20:47 |只看该作者
调用 adjust( value) 函数,判断 value 是不是 素数;
value = 2 ,是,直接返回;
value 为 2 以外的,求 value 除 已知素数的 余数,只要有一个,余数为 0,即 整除,value 不是 素数;都不整除, value 即为素数,保存。

不过,似乎有误: findvalue[find++]; 应为 findvalue[find++] = value  ;

只是 现在无法 调试!

论坛徽章:
0
3 [报告]
发表于 2008-09-20 20:52 |只看该作者
筛子的方法

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
4 [报告]
发表于 2008-09-20 21:31 |只看该作者
原帖由 nbkjbo 于 2008-9-20 20:52 发表
筛子的方法

不是这么叫的,应该是“筛法”

论坛徽章:
0
5 [报告]
发表于 2008-09-20 21:49 |只看该作者

回复 #1 xiaozhu2007 的帖子

“有足够的内存,要求尽量快”,似乎应该用查表法,提前算好放到内存里。

论坛徽章:
0
6 [报告]
发表于 2008-09-20 22:06 |只看该作者
楼主google:筛法求素。。

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
7 [报告]
发表于 2008-09-20 23:10 |只看该作者
筛法:
用awk写了一个

  1. #!/bin/awk -f
  2. {
  3.         x=$1;
  4.         for(i=3;i<=x;i+=2)
  5.                 a[i]=1;
  6.         y=int(sqrt($1));
  7.         for(j=3;j<=x;j+=2) {
  8.                 for(k=j+j;k<=x;k+=j){
  9.                         a[k]=0;
  10.                         t++;
  11.                 }
  12.         }
  13.         printf("2 ");
  14.         for(i=3;i<=x;i+=2)
  15.                 if(a[i]==1)
  16.                         printf("%d ",i);
  17.         printf("\n");
  18.         exit
  19. }

复制代码

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
8 [报告]
发表于 2008-09-21 00:22 |只看该作者
原帖由 cjaizss 于 2008-9-20 23:10 发表
筛法:
用awk写了一个

用 Haskell 写了一个:

  1. sieve :: [Integer] -> [Integer]
  2. sieve (x:xs) = x : sieve xs'
  3.              where xs' = filter (\y -> y `mod` x /= 0) xs

  4. primes = sieve $ 2:[3,5..]
复制代码

要得到小于 2000 的素数可用

  1. takeWhile (< 2000) primes
复制代码

[ 本帖最后由 MMMIX 于 2008-9-21 00:28 编辑 ]

论坛徽章:
0
9 [报告]
发表于 2008-09-21 13:04 |只看该作者
原帖由 aliking 于 2008-9-20 21:49 发表
“有足够的内存,要求尽量快”,似乎应该用查表法,提前算好放到内存里。


同意,2-2000,当然是用查表法最快了~

论坛徽章:
0
10 [报告]
发表于 2008-09-21 13:14 |只看该作者
原帖由 aliking 于 2008-9-20 21:49 发表
“有足够的内存,要求尽量快”,似乎应该用查表法,提前算好放到内存里。

同意
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP