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?

class Solution {
public:
    int climbStairs(int n) {
        /* recursive
        if(n<=0) return 0;
        else if(n==1) return 1;
        else if(n==2) return 2;
        else return  climbStairs(n-1) + climbStairs(n-2);
        */
        if(n <= 0) return 0;
        vector<int> v = vector<int>();
        v.push_back(1);
        v.push_back(2);
        while(v.size() < n) v.push_back(v[v.size()-1] + v[v.size()-2]);
        return v[n-1];
    }
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容