本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注!

作者| 慕课网精英讲师 JdreamZhang

斐波那契数列(Fibonacci sequence),也称之为黄金分割数列,由意大利数学家列昂纳多・斐波那契(Leonardo Fibonacci)提出。斐波那契数列指的是这样的一个数列:1、1、2、3、5、8、13、21、34、……,这个数列从第 3 项开始,每一项都等于前面两项之和。在数学上,斐波那契数列可以被递推的方法定义如下:

F(1)=1,F(2)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 3,n ∈ N*)

斐波那契数列是数学上面一个经典的例子,并且在日常生活中有很多应用,他还与黄金分割有着密不可分的联系,而且当 n 趋向于无穷大时,前一项与后一项的比值越来越逼近黄金分割值 0.618。

1. 用递归方法求解斐波那契数列

在本篇文章中,我们就需要利用递归的思想去求解斐波那契数列,当给出一个斐波那契中第几项的数字,然后求解出对应的斐波那契数值。在之前,我们已经定义了递归算法的相关概念,并且明确了需要应用递归时候的三要素:

  1. 递归终止条件;
  2. 递归终止时候的处理方法;
  3. 递归中重复的逻辑提取,缩小问题规模。

接下来,我们将利用递归的知识来解决斐波那契数列问题,明确在斐波那契数列求解问题中的递归三要素分别是什么。

斐波那契数列的递归终止条件
显然易见,通过观察斐波那契数列的定义,我们很容易发现当 n=1 或者 n=2 时,是斐波那契数列的递归终止条件,这个时候可以给出斐波那契数列的具体值。

斐波那契数列递归终止时候的处理方法
同样的,基于斐波那契数列的递推定义,当斐波那契数列达到终止条件 n=1 或者 n=2 时,我们也很容易发现对应 F(1)=1,F(2)=1,这就是斐波那契数列在递归终止时对应的取值。

斐波那契数列的递归重复逻辑提取
按照斐波那契数列的数学定义,F(n)=F(n - 1)+F(n - 2)(n ≥ 3,n ∈ N*),即当 n ≥ 3 时,斐波那契数列中这一项的值等于前面两项的值之和,这样便可以将求解一个比较大的斐波那契数列转化为求解较小数值的斐波那契数列值,这里面有重复逻辑可以递归复用。

例如,当我们求解斐波那契数列中的 F(5) 时,按照定义,我们有:

F(5) = F(4) + F(3) // 递归分解
= ( F(3) + F(2) ) + ( F(2)+F(1) ) // 递归求解
= [ ( F(2)+F(1) ) + 1 ] + ( 1+1 ) // 递归求解,遇到终止条件就求解
​ = [(1+1) +1 ]+(1+1) // 归并
​ = 3 + 2 // 归并
​ = 5 // 归并

2. 基于 Java 代码示例及实现讲解

在说明斐波那契数列的递归描述之后,我们看看如何用 Java 代码来实现对斐波那契数列的计算。

public class Fibonacci {public static void main(String[] args){System.out.println(fibonacci(1));System.out.println(fibonacci(2));System.out.println(fibonacci(3));System.out.println(fibonacci(4));System.out.println(fibonacci(5));}//斐波那契数列数列的计算private static int fibonacci(int n){//如果是终止条件,按照要求返回终止条件对应结果if( n==1 || n==2 ){return 1;}else {//非终止条件,按照要求把大的问题拆分成小问题,调用自身函数递归处理return fibonacci(n-1)+fibonacci(n-2);}}}
代码块12345678910111213141516171819202122

运行结果如下:

1
1
2
3
5
代码块12345

代码中的第 4 行至第 8 行分别调用斐波那契数列计算函数,计算出斐波那契数列中对应 n=1,2,3,4,5 时斐波那契数列的取值,进行结果比较,判断斐波那契数列程序实现是否正确。代码中的第 12 行至第 20 行是斐波那契数列应用递归方法进行斐波那契数列的计算,按照递归的三要素进行计算处理。

3. 小结

本节文章主要介绍了用递归思想求解斐波那契数列,我们了解了什么是斐波那契数列,并且将递归算法在斐波那契数列中进行了实际应用,需要掌握斐波那契数列的递归求解方法,并自己可以实现相关的代码实现,并清楚里面的每一步逻辑。

欢迎关注「慕课网」,发现更多IT圈优质内容,分享干货知识,帮助你成为更好的程序员!

什么是斐波那契数列?相关推荐

  1. java 斐波拉_Java实现斐波那契数列

    斐波纳契数列,又称黄金分割数列,指的是这样一个数列:1.1.2.3.5.8.13.21.--在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1,Fn=F(n-1)+F(n-2)(n&g ...

  2. 剑指offer:面试题10- I. 斐波那契数列

    写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项.斐波那契数列的定义如下: F(0) = 0, F(1) = 1 F(N) = F(N - 1) + F(N - 2), 其中 ...

  3. 用递归法计算斐波那契数列的第n项

     斐波纳契数列(Fibonacci Sequence)又称黄金分割数列,指的是这样一个数列:1.1.2.3.5.8.13.21.--在数学上,斐波纳契数列以如下被以递归的方法定义:F0=0,F1=1, ...

  4. 循环斐波那契数列_剑指offer #10 斐波那契数列

    (递归和循环)#10 斐波那契数列 一.斐波那契数列 定义: n = 0 , f(n) = 0 n = 1 , f(n) = 1 n > 1 , f(n) = f(n-1) + f(n-2) 思 ...

  5. 用C语言编写:判断一个≥2的整型数是否存在于斐波那契数列中?

    自己写的,感觉挺有成就感的,就展示出来吧! 判断一个≥2的整型数是否存在于斐波那契数列中? 若存在,则返回第几项:若不在,则返回-1 #include <stdio.h> long gen ...

  6. 算法(1)斐波那契数列

    1.0 问题描述 实现斐波那契数列,求第N项的值 2.0 问题分析 斐波那契数列最简单的方法是使用递归,递归和查表法同时使用,可以降低复杂度. 根据数列特点,同时进行计算的数值其实只有3个,所以可以使 ...

  7. NOIP模拟题 斐波那契数列

    题目大意 给定长度为$n$序列$A$,将它划分成尽可能少的若干部分,使得任意部分内两两之和均不为斐波那契数列中的某一项. 题解 不难发现$2\times 10^9$之内的斐波那契数不超过$50$个 先 ...

  8. 剑指offer_第7题_斐波那契数列

    题目描述 现在要求输入一个整数n 输出斐波那契数列的第n项(从0开始,第0项为0). n<=39 理解 斐波那契数列 因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子 ...

  9. 面试官问你斐波那契数列的时候不要高兴得太早

    增加内容 递归改进版 矩阵快速幂解法 通项表达式解法 列表法 斐波那契数列应用 前言 假如面试官让你编写求斐波那契数列的代码时,是不是心中暗喜?不就是递归么,早就会了.如果真这么想,那就危险了. 递归 ...

  10. 斐波那契数列性质【记住】

    斐波那契数列 斐波那契数列递推 F(1)=1,F(0)=0F(1)=1,F(0)=0F(1)=1,F(0)=0 F(n)=F(n−1)+F(n−2)F(n)=F(n-1)+F(n-2)F(n)=F(n ...

最新文章

  1. python同花顺交易接口是什么_我用 Python 预测了股票价格
  2. Prototype 字符串
  3. springboot实现拦截器
  4. Django进阶(CSRF、Ajax)
  5. sprintf 函数
  6. react+百度地图实现自定义图标
  7. Android常用提示框(dialog和popuwindow)
  8. 银行转账系统(Spring小项目)
  9. 2019运输科技领域最新SCI期刊影响因子正式发布,附三年IF变化趋势!
  10. ReportMachine
  11. ps图片去水印-图片一键去水印的app
  12. 安装VTN协调器操作步骤
  13. 《史蒂夫·乔布斯传》——童年篇有感
  14. New Concept English3 Lesson 2. Thirteen equals one【精讲学习笔记】
  15. UVA - 10041 Vito's Family (中位数)
  16. JD最新青龙面板+诺兰方舟星链计划对接傻妞芝士等机器人网页短信搭建教程+拉库教程+资产一对一推送教程
  17. 青龙面板2.8版本+Ninja 保姆级 服务器安装jd代挂教程——(二)
  18. dell电脑如何安装ubuntu系统_戴尔T630安装Ubuntu操作系统及Gaussian 09
  19. Typora配置smms图床
  20. BRISQUE UCIQE UIQM

热门文章

  1. 福建电脑网络协议dns服务器,福建移动dns的服务器地址是多少
  2. Mac 新建超级管理员账号
  3. android调用手机铃声
  4. kubernetes不同的命名空间下的容器能通信吗_深入浅出聊聊Kubernetes网络:容器网络初探...
  5. 代码的实质(图灵机怎么看待成状态图)
  6. Codeforces Round #816 (Div. 2) D. 2+ doors
  7. 大O大Omega大Theta
  8. 梦想世界 2014年8月14日服务器维护公告,2019年8月22日维护公告
  9. Android修改时间同步服务器
  10. 线性插值(Linear Interpolation):线性插值、双线性插值