设为首页收藏本站|繁體中文

Project1

 找回密码
 注册会员
搜索
查看: 12786|回复: 42
打印 上一主题 下一主题

[胡扯] 蛋疼数学程序帝!质数算法。

   关闭 [复制链接]

Lv3.寻梦者

孤独守望

梦石
0
星屑
3121
在线时间
1534 小时
注册时间
2006-10-16
帖子
4321

开拓者贵宾

1
发表于 2010-6-27 13:45:42 | 显示全部楼层
本帖最后由 IamI 于 2010-6-27 14:01 编辑

好吧2L我真的败给你了……常规筛数法,两层循环
  1. prime = (2..1000).to_a
  2. count = 0
  3. begin
  4.   p = prime[count]
  5.   for i in 2..(1000 / p)
  6.     prime.delete i * p
  7.   end
  8.   count += 1
  9. end until count >= prime.size
  10. p prime
复制代码

点评

= =b 不要这么直接……编辑了……你也自己和谐了吧  发表于 2010-6-27 14:00
喂喂!你把我的马甲都曝光我以后还怎么在6R混啊……  发表于 2010-6-27 13:59
菩提本非树,明镜本非台。回头自望路漫漫。不求姻缘,但求再见。
本来无一物,何处惹尘埃。风打浪吹雨不来。荒庭遍野,扶摇难接。
不知道多久更新一次的博客
回复 支持 反对

使用道具 举报

Lv3.寻梦者

孤独守望

梦石
0
星屑
3121
在线时间
1534 小时
注册时间
2006-10-16
帖子
4321

开拓者贵宾

2
发表于 2010-6-27 13:59:53 | 显示全部楼层
本帖最后由 IamI 于 2010-6-27 14:01 编辑
回楼上
prime = (2..1000).to_a
亿万星辰 发表于 2010-6-27 13:58

= =b 忘了……但是索引是从1号位置也就是2开始的……我是怎么神奇出来的……
修改完毕

点评

已经改了……跳过2的话偶数筛不掉比如4  发表于 2010-6-27 14:11
1 delete不掉… 2 恰巧又是第一个质数,所以count从0和从1起都无所谓了~  发表于 2010-6-27 14:02
1 delete不掉…  发表于 2010-6-27 14:01
回复 支持 反对

使用道具 举报

Lv3.寻梦者

孤独守望

梦石
0
星屑
3121
在线时间
1534 小时
注册时间
2006-10-16
帖子
4321

开拓者贵宾

3
发表于 2010-6-27 14:46:39 | 显示全部楼层
本帖最后由 IamI 于 2010-6-27 14:50 编辑
II 和上帝的眼睛都用了动态数组的 delete,无形中就丢失效率了

另外还有个不是特别重要的问题:乘法运算需 ...
紫苏 发表于 2010-6-27 14:43

那么用数组标记法……输出的时候再全扫描一次?
另外2的次方也可以邪恶一下……

好吧……我没看见前面的东西……去研究下
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

拿上你的纸笔,建造一个属于你的梦想世界,加入吧。
 注册会员
找回密码

站长信箱:[email protected]|手机版|小黑屋|无图版|Project1游戏制作

GMT+8, 2024-5-7 11:20

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表