def fib(n):
a = 1
b = 1
for i in range(n-1):#总共运算n-1次,从a=1,b=1开始,没运算一次,将结果
#带入下一次a,b=b,a+b中,最终结果就是n这个位置的
a,b=b,a+b
return a
print fib()
例如输入“5”,那么就是得到5,实际是从0开始的def fib(n):
if n == 1 or n == 2:
return 1
return fib(n-1)+fib(n-2)
print fib()
例如输入5,那么fib(5)就调用fib(5-1)+fib(5-2),返回fib(4)+fib(3),那么就继续计算fib(4)和fib(3),其中的fib(4)就调用return,就是fib(4-1)+fib(4-2),以此类推。最终触发if语句执行就会打断调用循环。依次返回值。fib(5)=3+2=5.如果需要某个段的斐波那契数,就等我研究第三个方法回来。。。