题目
# 直接递归解法,容易超时,python可以加个缓存装饰器,这样也算是将递归转换成迭代的形式了
class Solution:
@functools.lru_cache(100) # 缓存装饰器
def climbStairs(self, n: int) -> int:
if n == 1: return 1
if n == 2: return 2
return self.climbStairs(n-1) + self.climbStairs(n-2)
# 直接DP,新建一个字典或者数组来存储以前的变量,空间复杂度O(n)
class Solution:
def climbStairs(self, n: int) -> int:
dp = {}
dp[1] = 1
dp[2] = 2
for i in range(3,n+1):
dp[i] = dp[i-1] + dp[i-2]
return dp[n]
# 还是DP,只不过是只存储前两个元素,减少了空间,空间复杂度O(1)
class Solution:
def climbStairs(self, n: int) -> int:
if n==1 or n==2: return n
a, b, temp = 1, 2, 0
for i in range(3,n+1):
temp = a + b
a = b
b = temp
return temp
# 直接斐波那契数列的计算公式喽
class Solution:
def climbStairs(self, n: int) -> int:
import math
sqrt5=5**0.5
fibin=math.pow((1+sqrt5)/2,n+1)-math.pow((1-sqrt5)/2,n+1) #斐波拉契数列Fn公式
return int(fibin/sqrt5)
**总结:**
个人习惯前两种方法,希望每天一题leecode能坚持,希望能有成效,加油!!!
最后一个方法中,math.pow(x,y)表示x开y次方