Tyche_BO 2018-07-25 18:23 采纳率: 0%
浏览 1064
已采纳

用filter求素数时遇到的疑问

用filter求素数:

图片说明
图片说明

看廖老板的python教程里面
一直搞不懂上面这个程序,按照我自己的理解当程序运行到 it = filter(_not_divisible(n), it) 的时候难道 程序在调用函数_not_divisible(n) 里面的return lambda x: x % n > 0 难道不会一直运行吗? 一直无限的计算下去吗?后面我自己在这个代码后面加了个打印 会出现内存错误 ,这不正是引证了这个计算会无限的一直算出不能被n整除的数吗? 求大神给我解答下?谢谢

  • 写回答

3条回答 默认 最新

  • threenewbee 2018-07-25 19:13
    关注

    你修改了题目?
    根据你题目的算法,用筛选法也可以

     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, it)
    
    for n in primes():
        if n < 100:
            print(n)
        else:
            break;
    

    之所以不会无限执行,是因为这是生成器,所以for n in primes():这个循环其实是

     it = primes()
    while True:
        x = next(it)
        print(x)
        if (x > 100): break
    

    而每次调用next,

    def primes()中的代码会走到下一次yield就暂停了。

    展开全部

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部