题目描述:
假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

本题较为简单,主要用到递归思想
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);
}



















