python 教程的有 2 个地方看不懂
巴扎黑
巴扎黑 2016-11-11 17:13:44
0
1
952

用 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),传入一个函数和一个可迭代对象。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板