当前位置:  开发笔记 > 编程语言 > 正文

Python程序找到斐波纳契系列.更多Pythonic方式

如何解决《Python程序找到斐波纳契系列.更多Pythonic方式》经验,为你挑选了2个好方法。



1> Constantin..:

使用生成器是一种Pythonic方法,可以在保留内存的同时生成长序列:

def fibonacci():
  a, b = 0, 1
  while True:
    yield a
    a, b = b, a + b

import itertools
upto_4000000 = itertools.takewhile(lambda x: x <= 4000000, fibonacci())
print(sum(x for x in upto_4000000 if x % 2 == 0))



2> Jorenko..:

首先,我将fibo()作为生成器:

def fibo(a=-1,b=1,upto=4000000):
    while a+b

然后我也选择均匀作为生成器而不是列表理解.

print sum(i for i in fibo() if not i%2)

推荐阅读
放ch养奶牛
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有