#1848. 使用最小费用爬楼梯

使用最小费用爬楼梯

给你一个整数数组 cost ,其中 cost[i]cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。

请你计算并返回达到楼梯顶部的最低花费。

输入格式

第一行有一个整数 nn。代表台阶数。 第二行有 nn 个整数,依次代表从每个台阶向上排需要的支付的费用。

输出格式

只有一个数,爬到楼梯顶部的总花费。

3
10 15 20
15
10
1 100 1 1 1 100 1 1 100 1
6

样例 1 解释

将从下标为 1 的台阶开始。

  • 支付 15 ,向上爬两个台阶,到达楼梯顶部。

总花费为 15 。

样例 2 解释

你将从下标为 0 的台阶开始。

  • 支付 1 ,向上爬两个台阶,到达下标为 2 的台阶。
  • 支付 1 ,向上爬两个台阶,到达下标为 4 的台阶。
  • 支付 1 ,向上爬两个台阶,到达下标为 6 的台阶。
  • 支付 1 ,向上爬一个台阶,到达下标为 7 的台阶。
  • 支付 1 ,向上爬两个台阶,到达下标为 9 的台阶。
  • 支付 1 ,向上爬一个台阶,到达楼梯顶部。

总花费为 6 。

2 <= n <= 1000

0 <= cost[i] <= 999