python--生成器写斐波那契数列

最近刚学了一个python生成器,用生成器实现斐波那契数列

def fib(items):

    n=0

    a,b=0,1

    while n<=items:

           yield a

            a,b=b,a+b

            n+=1

num_str = input("请输入一个数:")

num=int(num_str)

F=fib(num)

for i in F:

    print(i)

总结:

 

总结:
生成器(函数),它记住上一次返回时在函数体中的位置。对生成器函数的第二次(或者第n次)调用
跳转至该函数的yeild暂停的位置处,继续执行。(上次调用的所有局部变量都保持状态 )

生成器不仅“记住”了它的数据状态,还记住了它在流程控制中的位置。

生成器的特点:
1.节约内存
2.迭代到下一次调用 时,所使用的参数是上一次所保留下的。
在整个所有函数调用参数,都保留“上一次”执行状态。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值