使用最小花費爬樓梯

2021-10-12 13:45:42 字數 1038 閱讀 9657

————(力扣第746題)

本題為「動態規劃題」

首先我們可以先建立乙個新的陣列(與原陣列長度相同)。,為保證體力值消耗最小,因此我們應取最小值。

// 建立乙個新陣列,保證與原陣列長度相同

int arr =new int[cost.length];

接著我們分析題,每次走一步或者兩步,因此保證前兩項數值不變,從索引2開始依次對之前的前一位和前兩位進行比較,選擇較小的,然後與當前所在位數值相加,賦值給新陣列的對應索引。此時即為走到現在所消耗的體力值 。

// 使新陣列的前兩位與原陣列相同

arr[0] = cost[0];

arr[1] = cost[1];

// 開始走台階,選擇最小的開始走並且使所走體力彙總到當前位

for(int i=2;i最後,依次遍歷陣列,當遍歷結束時比較陣列最後一位與最後兩位,選擇最小的即可。

// 返回最小值在新陣列的最後兩位

if(arr[arr.length-1] < arr[arr.length-2])else

最後完整**為:

class solution {

public int mincostclimbingstairs(int cost) {

// 建立乙個新陣列,保證與原陣列長度相同

int arr =new int[cost.length];

// 使新陣列的前兩位與原陣列相同

arr[0] = cost[0];

arr[1] = cost[1];

// 開始走台階,選擇最小的開始走並且使所走體力彙總到當前位

使用最小花費爬樓梯

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

使用最小花費爬樓梯

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

使用最小花費爬樓梯

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