跳台阶
发布日期:2021-05-14 17:05:11 浏览次数:9 分类:精选文章

本文共 580 字,大约阅读时间需要 1 分钟。

对于青蛙跳楼梯的问题,假设青蛙可以从台阶1和2起跳,那么我们需要找到青蛙跳到n级台阶的不同方法数。

首先,如果目标台阶数n小于等于2,只有一种或两种方法:

  • 如果n=1,只能有一种方法:1步。
  • 如果n=2,可以两种方法:1+1步,或者2步。

对于n大于2的情况,青蛙的跳法数等于去掉1级台阶后的方法数加上去掉2级台阶后的方法数。即:

  • JumpFloor(n) = JumpFloor(n-1) + JumpFloor(n-2)

这是因为青蛙在到达n级台阶之前,可以选择从n-1级跳过来(此时方法数为JumpFloor(n-1))或者从n-2级跳过来(此时方法数为JumpFloor(n-2))。

通过这个递归关系,可得JumpFloor(n)实际上是斐波那契数列的第n+1项。

public class Solution {    public int JumpFloor(int target) {        if (target <= 2) {            return target;        }        return JumpFloor(target - 1) + JumpFloor(target - 2);    }}

需要注意的是,递归会导致重复计算,较优的做法是使用记忆化技术存储已计算过的结果,避免重复计算,提高效率。

上一篇:二维数组的查找
下一篇:输入一个链表,反转链表后,输出新链表的表头。

发表评论

最新留言

第一次来,支持一个
[***.219.124.196]2025年05月01日 02时15分02秒