Tyche_BO 2018-07-26 02:23 采纳率: 0%
浏览 1063
已采纳

用filter求素数时遇到的疑问

用filter求素数:

图片说明
图片说明

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

  • 写回答

3条回答

  • threenewbee 2018-07-26 03: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条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器