美文网首页
Python中filter的应用案例-埃氏筛法求素数

Python中filter的应用案例-埃氏筛法求素数

作者: nonoBoy | 来源:发表于2019-03-06 12:37 被阅读0次
    1. 和map()类似,filter()也接收一个函数和一个序列。和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是True还是False决定保留还是丢弃该元素。
    2. 注意到filter()函数返回的是一个Iterator,也就是一个惰性序列,所以要强迫filter()完成计算结果,需要用list()函数获得所有结果并返回list。
    3. 运用:用filter求素数
    def _int_iter():#生成器生成从3开始的无限奇数序列
        n = 1
        while True:
            n = n + 2
            yield n
     
    def  _not_divisible(n):#定义筛选函数
        return lambda x:x % n > 0
     
    def primes():
        yield 2          #先返回一个2
        it = _int_iter() # 初始序列
        while True:
            n = next(it) # 返回序列的第一个数
            yield n
            it = filter(_not_divisible(n), it) # 构造新序列
    for n in primes():#构造循环条件,使之可以输出任何范围的素数序列
        if n < 1000:
            print(n)
        else:
            break
    

    相关文章

      网友评论

          本文标题:Python中filter的应用案例-埃氏筛法求素数

          本文链接:https://www.haomeiwen.com/subject/zhrtpqtx.html