题解 | #跳台阶#

跳台阶

https://www.nowcoder.com/practice/8c82a5b80378478f9484d87d1c5f12a4

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param number int整型 
     * @return int整型
     */
    public int jumpFloor (int number) {
        // write code here
        // 算法核心思想:递归回溯

        return process(number);
    }

    public int process(int n) {
        // 递归出口
        if (n == 1) {
            // 如果只有1阶台阶,则只有1种跳法
            return 1;
        }
        if (n == 2) {
            // 如果有2阶台阶,则有2种跳法
            return 2;
        }

        // 分支搜索
        // 其余任意情况,可拆解成两大类情况
        // 从n-2阶跳2阶 + 从n-1阶跳1阶
        return process(n - 2) + process(n - 1);
    }
}

全部评论

相关推荐

06-03 15:32
点赞 评论 收藏
分享
04-19 11:59
门头沟学院 Java
卷不动辣24314:挂,看来不该投这个部门的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务