递归——LeetCode70. Climbing Stairs

题目:

You are climbing a stair case. It takes n steps to reach to the top.


Each time you can either climb 1 or 2 steps. In how many distinct ways can you climb to the top?

分析:


Climbing Stairs 爬楼梯问题是递归中非常基础的一道题。

处理递归的问题,有非常重要和程序化的三个步骤:

1). 找到 base case

这道题通过简单的枚举,就可以找到 base case:当楼层为1的时候,有一种方法;当楼层为2的时候,有两种方法。


2). 找到 recursion rule

找到 recursion rule 的方法有两种。

第一种方法仍然是通过简单的枚举总结出规律,例如,当 n = 3 时,有3种方法,等于 f (n=1) + f (n=2);当 n = 4 时,有5种方法,等于 f (n=2) + f (n=3)。

第二种方法是通过逻辑分析,抽象出 recursion rule 的公式。因为一次只能走一步或者两步,所以 走n步的方法 = 走n-1步的方法 + 走 n-2 步的方法,抽象公式为 f (n) = f (n-1) + f (n-2)。

我个人更倾向于第二种方法,应该培养逻辑思维抽象出 recursion rule 的方法,因为很多复杂的 recursion rule 并不能通过简单的枚举和加减法找出规律。


代码:

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

Ps:

值得一提的是,LeetCode70 用递归的方法并不能通过,会显示 Time Limit Exceed,因为OJ想要的解法是通过动态规划。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值