通过python求斐波那契数列

斐波那契数列:

一个数列中前两个数相加等于第三个数:(据说在炒股中经常使用)

 

这里需要使用到递归;在python中,在函数体中调用自身的行为就是递归,python不允许无限递归,所以必须给一个出口。

一个简单的递归需求:

列出2^1-2^32之间的所有值

代码段:

a = 2**32

def fun(n):
    if n < a:
        result = fun(n*2)
        print (result)
    return n

fun(1)

解析——

1,定义一个函数fun(n),这个函数中进行了一次if判断,判断给定的参数是否小于a,(a=2*32)

2,如果条件满足,则定义一个变量 result,这个变量调用了函数fun(),这样就进入了递归,并且传递的参数是n*2

3,经过多次递归后,会走到2147483648*2,结果就是2*32 = 4294967296,这样if语句就不成立了,递归终止。

 

通过这个原理,我们就可以用递归来求斐波那契数列了:

代码段:

def fun(arg1,arg2,stop):
    arg3 = arg1 + arg2
    print(arg3)
    if arg3 < stop:
        fun(arg2,arg3,stop)

if __name__ == '__main__':
    fun(0,1,30)

结果:

1
2
3
5
8
13
21
34

这个函数被递归了7次,第七次的时候arg3 = 34,导致if语句不成立,递归被终结。

 

转载于:https://www.cnblogs.com/alben-cisco/p/6911126.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值