如何用 python 计算十亿内的素数总和?

2015-04-18 03:15:08 +08:00
 napretep
今天想加个QQ群,得回答这个问题才能通过请求。
我本来想想很简单啊用下面这个式子就能算了。
reduce(lambda x,y:x+y,[x for x in range(1,N+1,2) if len([y for y in range(1,x+1,2) if x%y==0])==2],2)
结果到后来抛出个错误说MemoryError。
研究了好会儿还是没什么好法子,各位有什么看法?
8214 次点击
所在节点    Python
21 条回复
monkeymonkey
2015-04-19 00:03:00 +08:00
只要求和的话,把素数表存成文件扫一遍不就算出和了么,也不需要多少内存。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/184482

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX