题目描述:
假设你正在爬楼梯。需要 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); }
还没有评论,来说两句吧...