假设你正在爬楼梯。需要
n阶你才能到达楼顶。每次你可以爬
1或2个台阶。你有多少种不同的方法可以爬到楼顶呢?示例 1:
输入:n = 2 输出:2 解释:有两种方法可以爬到楼顶。 1. 1 阶 + 1 阶 2. 2 阶示例 2:
输入:n = 3 输出:3 解释:有三种方法可以爬到楼顶。 1. 1 阶 + 1 阶 + 1 阶 2. 1 阶 + 2 阶 3. 2 阶 + 1 阶提示:
1 <= n <= 45
cppclass Solution { public: int climbStairs(int n) { if(n<=2) return n; vector<int> dp(n+1); dp[1]=1; dp[2]=2; for(int i=3;i<=n;i++) { dp[i]=dp[i-1]+dp[i-2]; } return dp[n]; } };
LeetCode 70. 爬楼梯
Liangwei Lin2026-05-14 14:31
相关推荐
To_OC4 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑饼干哥哥4 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例地平线开发者5 小时前
Transformer模型部署之性能优化指南地平线开发者6 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子半个落月9 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白小月土星10 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想小月土星10 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化To_OC1 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass鱼鱼不愚与1 天前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》