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?
Note: Given n will be a positive integer.
Example 1:
Input: 2
Output: 2
Explanation: There are two ways to climb to the top.
1. 1 step + 1 step
2. 2 steps
Example 2:
Input: 3
Output: 3
Explanation: There are three ways to climb to the top.
1. 1 step + 1 step + 1 step
2. 1 step + 2 steps
3. 2 steps + 1 step
Tags: Dynamic Programming
题意是爬楼梯,每次你只能爬一步或者两步,问到顶层共有多少种方案。我们假设到顶层共有 f(n)
种,那么 f(n) = f(n - 1) + f(n - 2)
肯定是成立的,意思就是我们迈向顶层的最后一步是在倒数第一级台阶或者在倒数第二级台阶。算法我对空间复杂度进行了优化,因为在迭代过程中只需要两个变量即可。
Java:
class Solution {
public int climbStairs(int n) {
int a = 1, b = 1;
while (--n > 0) {
b += a;
a = b - a;
}
return b;
}
}
本来想用递归的, 发现超时了, 就改用循环了 kotlin(168ms/100.00%):
class Solution {
fun climbStairs(n: Int): Int {
if (n == 1) return 1
if (n == 2) return 2
var a = 1
var b = 2
var c: Int
for (i in 2 until n) {
c = b
b += a
a = c
}
return b
}
}
/**
* @param {number} n
* @return {number}
*/
var climbStairs = function(n) {
if(n == 1) {return 1}
if(n == 2) {return 2}
var step1 = 1, step2 = 2, x;
for(var i = 2 ; i < n; i++) {
x = step2
step2 += step1
step1 = x
}
return step2
};
如果你同我们一样热爱数据结构、算法、LeetCode,可以关注我们 GitHub 上的 LeetCode 题解:LeetCode-Solution