[力扣]——70.爬楼梯

题目描述:

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

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

本题较为简单,主要用到递归思想

cs 复制代码
int fun(int n,int memo[])
{
    if(memo[n]!=-1)     //如果备忘录中已经有记录了,直接返回值
    return memo[n];
    int res=fun(n-1,memo)+fun(n-2,memo);
    memo[n]=res;        //备忘录中还没有记录,则计算出方法数并存入备忘录
    return res;
}
int climbStairs(int n)
{
    int memo[100];
    memset(memo,-1,sizeof(memo));   //初始化备忘录
    memo[1]=1;          
    memo[2]=2;
    return fun(n,memo);
}
相关推荐
xu_yule5 分钟前
算法基础—组合数学
c++·算法
爱尔兰极光6 分钟前
LeetCode--移除元素
算法·leetcode·职场和发展
Tansmjs18 分钟前
C++中的工厂模式变体
开发语言·c++·算法
naruto_lnq20 分钟前
多平台UI框架C++开发
开发语言·c++·算法
Tingjct21 分钟前
十大排序算法——交换排序(一)
c语言·开发语言·数据结构·算法·排序算法
MM_MS23 分钟前
Halcon图像点运算、获取直方图、直方图均衡化
图像处理·人工智能·算法·目标检测·计算机视觉·c#·视觉检测
每天要多喝水27 分钟前
贪心算法专题Day22
算法·贪心算法
ujainu31 分钟前
Flutter + OpenHarmony 游戏开发进阶:动态关卡生成——随机圆环布局算法
算法·flutter·游戏·openharmony
PPPPPaPeR.32 分钟前
程序地址空间
linux·算法
苦藤新鸡34 分钟前
51.课程表(拓扑排序)-leetcode207
数据结构·算法·leetcode·bfs