190 使用最小花費爬樓梯

2021-09-09 01:20:49 字數 1105 閱讀 8075

題目描述:

陣列的每個索引做為乙個階梯,第 i個階梯對應著乙個非負數的體力花費值 costi。

每當你爬上乙個階梯你都要花費對應的體力花費值,然後你可以選擇繼續爬乙個階梯或者爬兩個階梯。

您需要找到達到樓層頂部的最低花費。在開始時,你可以選擇從索引為 0 或 1 的元素作為初始階梯。

示例 1:

輸入: cost = [10, 15, 20]

輸出: 15

解釋: 最低花費是從cost[1]開始,然後走兩步即可到階梯頂,一共花費15。

示例 2:

輸入: cost = [1, 100, 1, 1, 1, 100, 1, 1, 100, 1]

輸出: 6

解釋: 最低花費方式是從cost[0]開始,逐個經過那些1,跳過cost[3],一共花費6。

注意:cost 的長度將會在 [2, 1000]。

每乙個 cost[i] 將會是乙個integer型別,範圍為 [0, 999]。

很明顯使用的是動態規劃來進行

只不過這個動態規劃很簡單,因此就不做多解釋了,**如下:

class solution 

if(cost.length == 1)

if(cost.length == 2)

int dp = new int[cost.length + 1];

//dp為爬n個樓梯的最小值

//初始化一些

dp[0] = 0;

dp[1] = cost[0];

dp[2] = cost[1];

for (int i = 2; i < cost.length; i++)

return math.min(dp[cost.length - 1], dp[cost.length]);

}}

排名靠前的**,跟我的思路一樣啊,但是人家的效率就是高啊

class solution 

for(int i = 2; i < cost.length; i++)

return math.min(cost[len - 1], cost[len - 2]);

}}

使用最小花費爬樓梯

陣列的每個索引做為乙個階梯,第 i個階梯對應著乙個非負數的體力花費值 cost i 索引從0開始 每當你爬上乙個階梯你都要花費對應的體力花費值,然後你可以選擇繼續爬乙個階梯或者爬兩個階梯。您需要找到達到樓層頂部的最低花費。在開始時,你可以選擇從索引為 0 或 1 的元素作為初始階梯。示例 1 輸入 ...

使用最小花費爬樓梯

力扣第746題 本題為 動態規劃題 首先我們可以先建立乙個新的陣列 與原陣列長度相同 為保證體力值消耗最小,因此我們應取最小值。建立乙個新陣列,保證與原陣列長度相同 int arr new int cost.length 接著我們分析題,每次走一步或者兩步,因此保證前兩項數值不變,從索引2開始依次對...

使用最小花費爬樓梯

陣列的每個下標作為乙個階梯,第 i 個階梯對應著乙個非負數的體力花費值 cost i 下標從 0 開始 每當你爬上乙個階梯你都要花費對應的體力值,一旦支付了相應的體力值,你就可以選擇向上爬乙個階梯或者爬兩個階梯。請你找出達到樓層頂部的最低花費。在開始時,你可以選擇從下標為 0 或 1 的元素作為初始...