projecteuler.net解题记录,参考了肥猫的(7题)

第4题:
找出第10001个质数
  1. # -*- coding: gb2312 -*-
  2. # 找出第10001个质数
  3. import math
  4. import time
  5. start = time.time()
  6. value, s, i = 3, 2, 1
  7. max = 2000000
  8. t0 = int(math.sqrt(max))+1
  9. market = [1] * max
  10. #while value < max:
  11. while i < 10001:
  12.     if market[value]:
  13.         s += value
  14.         i += 1
  15.         market[value] = 0
  16.         if value < t0:
  17.             for j in xrange(value**2,max,value*2):
  18.                 market[j] = 0
  19.     value += 2
  20. print s,i,value-2
  21. end = time.time()
  22. print end-start
496270154 10001 104743
0.389999866486

经过了对内部for循环的下限,步长的微调,对是否执行该循环也提前进行了判断,在较小范围内进行质数判定时,可以认为此种填充算法是最快的了.来源于第10题的达人回复,对其进行了改进.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值