题解 | #跳台阶#

跳台阶

https://www.nowcoder.com/practice/bfb2a2b3cdbd4bd6bba0d4dca69aa3f0

#include <iostream>

using namespace std;

int climbStairs(int n) {

    static int dp[100] = {0};    // 静态数组,用于保存计算结果

    if (n == 1) {

        return 1;

    }

    if (n == 2) {

        return 2;

    }

    if (dp[n] !=

            0) {           // 如果之前已经计算过,则直接返回之前存储的结果

        return dp[n];

    }

    int result = climbStairs(n - 1) + climbStairs(n - 2); // 递推计算

    dp[n] = result;             // 保存计算结果

    return result;

}

int main() {

    int n;

    cin>>n;

    int result = climbStairs(n);

    cout << result << endl;     // 输出结果

    return 0;

}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-10 11:31
点赞 评论 收藏
分享
05-20 13:59
门头沟学院 Java
米黑子米黑子:你这个成绩不争取下保研?
点赞 评论 收藏
分享
头顶尖尖的程序员:我是26届的不太懂,25届不应该是找的正式工作吗?为什么还在找实习?大四还实习的话是为了能转正的的岗位吗
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-08 12:10
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务