跳台阶问题和斐波那契数列

题目:一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。

现在我们再来讨论一般情况:我们把n 级台阶时的跳法看成是n 的函数,记为f(n)。
当n>2 时,第一次跳的时候就有两种不同的选择:一是第一次只跳1 级,此时跳法数目等于后面剩下的n-1 级台阶的跳法数目,即为f(n-1);
另外一种选择是第一次跳2 级,此时跳法数目等于后面剩下的n-2 级台阶的跳法数目,即为f(n-2)。
因此n 级台阶时的不同跳法的总数f(n) = f(n-1) + f(n-2)。
首先我们考虑最简单的情况:如果只有1 级台阶,那显然只有一种跳法,如果有2 级台阶,那就有两种跳的方法了:一种是分两次跳,每次跳1 级;另外一种就是一次跳2 级。

所以可以使用递归算法:


如果 n<=2
    返回 n 
否则
    f(n-1) + (f-2)  (n>2)

这就是我们经常看到的斐波那契数列。

递推公式
斐波那契数列:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, …
如果设F(n)为该数列的第n项(n∈N*),那么这句话可以写成如下形式::F(n)=F(n-1)+F(n-2)
显然这是一个推递数列。

斐波那契数列在生活中可以解决很多的问题:

兔子繁殖问题 

斐波那契数列又因数学家列昂纳多·斐波那契以兔子繁殖为例子而引入,故又称为“兔子数列”。 一般而言,兔子在出生两个月后,就有繁殖能力,一对兔子每个月能生出一对小兔子来。如果所有兔子都不死,那么一年以后可以繁殖多少对兔子? 

我们不妨拿新出生的一对小兔子分析一下: 第一个月小兔子没有繁殖能力,所以还是一对 两个月后,生下一对小兔对数共有两对 三个月以后,老兔子又生下一对,因为小兔子还没有繁殖能力,所以一共是三对一共是三对。

斐波那契数列中的斐波那契数会经常出现在我们的眼前——比如松果、凤梨、树叶的排列、某些花朵的花瓣数(典型的有向日葵花瓣),蜂巢,蜻蜓翅膀,超越数e(可以推出更多),黄金矩形、黄金分割、等角螺线,十二平均律等。




斐波那契数与植物花瓣3………………………
百合和蝴蝶花5……………………
蓝花耧斗菜、金凤花、飞燕草、毛茛花8………………………
翠雀花13………………………
金盏和玫瑰21……………………
紫宛34、55、89……………雏菊
斐波那契数还可以在植物的叶、枝、茎等排列中发现。例如,在树木的枝干上选一片叶子,记其为数0,然后依序点数叶子(假定没有折损),直到到达与那些叶子正对的位置,则其间的叶子数多半是斐波那契数。叶子从一个位置到达下一个正对的位置称为一个循回。叶子在一个循回中旋转的圈数也是斐波那契数。在一个循回中叶子数与叶子旋转圈数的比称为叶序(源自希腊词,意即叶子的排列)比。多数的叶序比呈现为斐波那契数的比。

黄金分割
随着数列项数的增加,前一项与后一项之比越来越逼近黄金分割的数值0.6180339887..…

杨辉三角
将杨辉三角左对齐,成如图所示排列,将同一斜行的数加起来,即得一数列1、1、2、3、5、8、……

贴上递归算法的代码:

class Solution {
public:
    int jumpFloor(int number) {
        if(number<=2){
            return number;

        }else{
            //大约等于2的时候,可以使用递归函数
            return jumpFloor(number-1)+jumpFloor(number-2);
        }
    }
};
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
青蛙台阶问题斐波那契数列是经典的编程问题。我们来分别介绍一下。 1. 青蛙台阶问题 一只青蛙一可以上1级台阶,也可以上2级。求该青蛙一个n级的台阶总共有多少种法? 解答: 我们可以用动态规划的思想来解决这个问题。我们用f(n)来表示上n级台阶法数目。对于第一,我们有两种选择:一级或者两级。如果第一一级,那么剩下的n-1级台阶就有f(n-1)种法;如果第一两级,那么剩下的n-2级台阶就有f(n-2)种法。因此,总的法数目就是f(n) = f(n-1) + f(n-2),这就是斐波那契数列的定义。 那么,我们可以写出如下的Python代码来实现青蛙台阶问题: ```python def jumpFloor(number): if number == 1: return 1 if number == 2: return 2 a, b = 1, 2 for i in range(3, number+1): a, b = b, a+b return b ``` 2. 斐波那契数列 斐波那契数列是指这样一个数列:0、1、1、2、3、5、8、13、21、34、……,在数学上,斐波那契数列以如下被以递归的方法定义: $$ F_0 = 0, F_1 = 1, F_n = F_{n-1} + F_{n-2} (n \geq 2) $$ 解答: 斐波那契数列具有很好的递归性质,因此我们可以用递归的方式来求解。另一种方法是使用动态规划的思想,用f(n)来表示第n个斐波那契数,那么有f(n) = f(n-1) + f(n-2)。 我们可以写出如下的Python代码来实现斐波那契数列: ```python def Fibonacci(n): if n == 0: return 0 if n == 1: return 1 a, b = 0, 1 for i in range(2, n+1): a, b = b, a+b return b ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值