心路历程:
这道题是之前学院的一道复试题,大家都没怎么刷过算法题,只记得当年凭借几次试错自己把这道题做出来了,当时也不知道动态规划之类的。
正常来讲,这种找不到循环结构的题一般都是递归解决。
注意的点:
1、注意返回值种加号的含义
解法:动态规划
python
class Solution:
def climbStairs(self, n: int) -> int:
# dp
@cache # 不加这个装饰器甚至无法AC
def dfs(i):
if i <= 2:
return i
return dfs(i-1) + dfs(i-2)
return dfs(n)