70. Climbing Stairs
Posted 三颗心
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了70. Climbing Stairs相关的知识,希望对你有一定的参考价值。
You are climbing a stair case. It takes n steps to reach to the top.
Each time you can either climb 1 or 2 steps. In how many distinct ways can you climb to the top?
递推公式为f(n)=f(n-1)+f(n-2)
每个元素仅依赖于前两个元素。
1 class Solution { 2 public: 3 int climbStairs(int n) { 4 int result[3] = {0,1,2}; 5 if(n < 3){ 6 return result[n]; 7 } 8 9 int f1 = 1; 10 int f2 = 2; 11 int fn = 0; 12 13 for(int i = 3; i <= n; i++ ){ 14 fn = f1 + f2; 15 f1 = f2; 16 f2 = fn; 17 } 18 return fn; 19 } 20 };
以上是关于70. Climbing Stairs的主要内容,如果未能解决你的问题,请参考以下文章