推出一个新系列,《看图轻松理解数据结构和算法》,主要使用图片来描述常见的数据结构和算法,轻松阅读并理解掌握。本系列包括各类堆、各类队列、各类列表、各类树、各类图、各类排序等等几十篇的样子。mysql
斐波那契(Leonardo Pisano ,Fibonacci, Leonardo Bigollo,1175年-1250年),又称列奥纳多,是中世纪意大利数学家。他是西方第一个研究斐波那契数列的人,并将现代书写数和乘数的位值表示法系统引入欧洲。主要做品包括《计算之书》、《几何实践》、《平方数书》等。算法
斐波那契数列,又称黄金分割数列或兔子数列,该数列为0、一、一、二、三、五、八、1三、2一、3四、...,能够看到它的性质是前两项之和等于后一项。sql
斐波那契数列能够用来描述兔子繁殖问题,通常而言,兔子在出生两个月后就有繁殖能力,一对兔子每月能生出一对小兔子。若是全部兔子都不死,那么一年后能够繁殖多少对兔子?实际结果以下,第一个月和第二个月,兔子尚未繁殖能力,因此都只有1对。第三个月生下第一对,总共有2对。第四个月老兔子继续生下一对,另外一对尚未繁殖能力,总共有3对。以此类推,第五个月到第十二个月的兔子对数对应以下。bash
月数 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
对数 | 1 | 1 | 2 | 3 | 5 | 8 | 13 | 21 | 34 | 55 | 89 | 144 |
int fib(int n){
if (n == 0)
return 0;
if (n == 1)
return 1;
return fib(n - 1) + fib(n - 2);
}
复制代码
假如n=4时,看看递归过程的堆栈状况。网络
① 调用fib函数,传入参数值4。数据结构
② fib(4)=fib(3)+fib(2),须要继续调用fib(3),而fib(2)先不进入执行堆栈。并发
③ fib(3)=fib(2)+fib(1),须要继续调用fib(2),fib(1)先不进入执行堆栈。机器学习
④ fib(2)=fib(1)+fib(0),须要继续调用fib(1),fib(0)先不进入执行堆栈。数据结构和算法
⑤ fib(1)返回1,中止往下调用,而后上一步的fib(0)进入堆栈。函数
fib(0)返回0,则 ④ 中的fib(2)=fib(1)+fib(0)=1
而后,堆栈回到③中,由于fib(3)=fib(2)+fib(1),因此将fib(1)入栈。
fib(1)返回1,则 ③ 中的fib(3)=fib(2)+fib(1)=1+1=2。
而后,堆栈回到 ② 中,由于fib(4)=fib(3)+fib(2),因此将fib(2)入栈。而fib(2)=fib(1)+fib(0),因而将fib(1)入栈。此时fib(1)直接返回1,而后继续将fib(0)入栈。则fib(2)=fib(1)+fib(0)=1,最后fib(4)=fib(3)+fib(2)=3。
-------------推荐阅读------------
个人开源项目汇总(机器&深度学习、NLP、网络IO、AIML、mysql协议、chatbot)
跟我交流,向我提问:
欢迎关注: