[力扣]——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);
}
相关推荐
Tisfy7 分钟前
LeetCode 2483.商店的最少代价:两次遍历 -> 一次遍历
算法·leetcode·题解·遍历
YGGP18 分钟前
【Golang】LeetCode 279. 完全平方数
算法·leetcode
im_AMBER24 分钟前
Leetcode 87 等价多米诺骨牌对的数量
数据结构·笔记·学习·算法·leetcode
月明长歌33 分钟前
【码道初阶】Leetcode771 宝石与石头:Set 判成员 vs List 判成员(同题两种写法的差距)
java·数据结构·leetcode·list·哈希算法·散列表
import_random34 分钟前
[算法]时间序列(介绍)
算法
wuk99838 分钟前
MATLAB中求解和分析马蒂厄方程
人工智能·算法·matlab
Wang201220131 小时前
LSTM和Transformer对比
人工智能·算法·架构
KingRumn1 小时前
Linux进程间通信之D-Bus
linux·算法
fufu03111 小时前
Linux环境下的C语言编程(四十九)
linux·c语言·算法
YGGP1 小时前
【Golang】LeetCode198. 打家劫舍
算法·leetcode