python 教程的有 2 个地方看不懂
巴扎黑
巴扎黑 2016-11-11 17:13:44
[Python讨论组]

用 Python 来实现这个算法,可以先构造一个从 3 开始的奇数序列:

def _odd_iter():
   n = 1
   while True:
       n = n + 2
       yield n

注意这是一个生成器,并且是一个无限序列。

然后定义一个筛选函数:

def _not_divisible(n):
   return lambda x: x % n > 0

最后,定义一个生成器,不断返回下一个素数:

def primes():
   yield 2
   it = _odd_iter() # 初始序列
   while True:
       n = next(it) # 返回序列的第一个数
       yield n
       it = filter(_not_divisible(n), it) # 构造新序列这个生成器先返回第一个素数 2 ,然后,利用 filter()不断产生筛选后的新的序列。


巴扎黑
巴扎黑

全部回复(1)
面对疾风吧

@sensui7 filter(function, iterable),传入一个函数和一个可迭代对象。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号