鱼C论坛

 找回密码
 立即注册
查看: 3525|回复: 2

[学习笔记] python 49课,计算2000000以下的素数的和

[复制链接]
发表于 2018-3-6 12:18:38 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. import math
  2. def is_primt(data):
  3.     for x in range(2,int(math.sqrt(data))+1):   #一个数的素数集合不会超过他的平方根+1,例如100是由2*2*5*5组成,这里是为了减少for的循环次数,提高效率
  4.         if not data%x:
  5.             return False
  6.     else:
  7.         return True

  8. def get_primt(data):
  9.     while True:
  10.         if is_primt(data):
  11.            yield data
  12.         data+=1

  13. def sum_num():
  14.     result=0
  15.     for i in get_primt(2):
  16.         if i<2000000:
  17.             result+=i
  18.         else:
  19.             print(result)
  20.             return

  21. if __name__=="__main__":
  22.     sum_num()
复制代码


生成器的用法
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-4-3 21:48:45 | 显示全部楼层
学习一下
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-19 07:33:34 | 显示全部楼层
用比他小的素数集合来除效率更高吧,反正你都要存更小的素数的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-14 17:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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