# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
#
# @param cost int整型一维数组
# @return int整型
#
class Solution:
def minCostClimbingStairs(self , cost: List[int]) -> int:
# write code here
dp={} #表示上到第几层台阶所需的最小花费
dp[0]=dp[1]=0 #初始化
n=len(cost) #获取台阶数量
#判断到达第i层时,跨一层台阶还是两层台阶花费较少
for i in range(2,n+1):
dp[i]=min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2])
return dp[n] #当有n层台阶时的最小花费