编程语言
首页 > 编程语言> > 爬楼梯----(算法学习笔记21.5.23)

爬楼梯----(算法学习笔记21.5.23)

作者:互联网

有这样一个问题:

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

思考 当只有一层的时候只有一个方法,当有两层的时候有两个方法,当有三层的时候有三个方法,因此我们不难发现,n阶的爬法呈现出斐波那契数列,到n阶时的方法设为f(n) = f(n-1) + f(n-2)

因此我的思路就是用斐波那契数列求和来求解方法

第一次书写是应用递归法求解,代码如下:

class Solution {
    public int climbStairs(int n) {
        if(n==1) return 1;
        if(n==2) return 2;
        return climbStairs(n-1)+climbStairs(n-2);
    }
}

但是在执行过程中出现了问题---------------超出时间限制

由于消耗时间过长,我不得不采用另一种方法来求和

我的思路是建立一个数组arr arr[0]对应第一项,arr[1]对应第二项,以此类推,在重写了方法之后,代码如下:

class Solution {
    public int climbStairs(int n) {
        int foot[] = new int[n];
        for(int i = 0; i < n; i++){
            if(i==0) foot[0] = 1;
            if(i==1) foot[1] = 2;
            if(i>=2) foot[i] = foot[i-1] + foot[i-2];
        }
        return foot[n-1];
    }
}

由于第一项对应foot[0],第二项对应foot[1],所以最后输出的应该是foot[n-1];很显然,该段代码很快通过了检测。

若有其他方法,希望各位大神指导.

 

 

 

 

标签:21.5,arr,return,23,int,----,climbStairs,foot,方法
来源: https://blog.csdn.net/qq_52246078/article/details/117198030