LeetCode算法心得——使用最小花費爬樓梯(記憶化搜索+dp)

大家好,我是晴天學長,很重要的思想動規思想,需要的小伙伴可以關注支持一下哦!后續會繼續更新的。💪💪💪


1)使用最小花費爬樓梯

在這里插入圖片描述

給你一個整數數組 cost ,其中 cost[i] 是從樓梯第 i 個臺階向上爬需要支付的費用。一旦你支付此費用,即可選擇向上爬一個或者兩個臺階。
你可以選擇從下標為 0 或下標為 1 的臺階開始爬樓梯。
請你計算并返回達到樓梯頂部的最低花費。

示例 1:

輸入:cost = [10,15,20]
輸出:15
解釋:你將從下標為 1 的臺階開始。
支付 15 ,向上爬兩個臺階,到達樓梯頂部。
總花費為 15 。
示例 2:

輸入:cost = [1,100,1,1,1,100,1,1,100,1]
輸出:6
解釋:你將從下標為 0 的臺階開始。
- 支付 1 ,向上爬兩個臺階,到達下標為 2 的臺階。
- 支付 1 ,向上爬兩個臺階,到達下標為 4 的臺階。
- 支付 1 ,向上爬兩個臺階,到達下標為 6 的臺階。
- 支付 1 ,向上爬一個臺階,到達下標為 7 的臺階。
- 支付 1 ,向上爬兩個臺階,到達下標為 9 的臺階。
- 支付 1 ,向上爬一個臺階,到達樓梯頂部。
總花費為 6 。

提示:

2 <= cost.length <= 1000
0 <= cost[i] <= 999


2) .算法思路

  • 有點像變了的樣子的打家劫舍,可以打劫附近的房子了。

3) .算法步驟

定義一個整型數組 memo 和 cost,用于存儲記憶化搜索的結果和每個樓梯的代價。
創建 minCostClimbingStairs 方法來啟動算法。在該方法中,初始化 memo 數組和 cost 數組,并將 memo 數組的所有元素初始化為 -1。
調用 dfs 方法,將起始索引設為 cost.length - 1(最后一個樓梯),并返回從最后一個樓梯開始上樓梯的最小代價。
在 dfs 方法中,首先檢查是否已經搜索過當前索引 i 的結果。如果在 memo 數組中存在已計算的值,則直接返回該值作為結果,避免重復計算。
如果當前索引 i 小于 0,表示已經超出樓梯范圍,返回 0。
否則,根據動態規劃的思想,當前樓梯 i 的最小代價等于從前一個樓梯 i-1 或者前兩個樓梯 i-2 上來的最小代價加上當前樓梯的代價。使用遞歸調用 dfs 方法,分別計算從 i-1 樓梯和 i-2 樓梯上來的最小代價,并將它們與當前樓梯的代價相加并取最小值。
將計算得到的結果存儲在 memo 數組中,以備后續使用。
返回當前索引 i 的結果作為最終答案,即從最后一個樓梯出發的最小代價。


4).代碼示例

方法1:記憶化搜索。class Solution {int[] memo;int[] cost;public int minCostClimbingStairs(int[] cost) {memo = new int[1000];this.cost = cost;Arrays.fill(memo, -1);return Math.min(dfs(cost.length - 1), dfs(cost.length - 2));}//變相的打家劫舍, 到樓梯發現已經爬上來了,不能選擇不爬private int dfs(int i) {if (i < 0) return 0;if (memo[i] != -1) return memo[i];int result = Math.min(dfs(i - 1) + cost[i], dfs(i - 2) + cost[i]);memo[i] = result;return result;}}
方法2:動態規劃dp
//感興趣的小伙伴可以用一個數組來打表,優化空間復雜度。class Solution {public int minCostClimbingStairs(int[] cost) {int[] dp = new int[cost.length];dp[0] = cost[0];dp[1] = cost[1];for (int i = 2; i < dp.length; i++) {dp[i] = Math.min(dp[i - 1] + cost[i], dp[i - 2] + cost[i]);}return Math.min(dp[cost.length - 1], dp[cost.length - 2]);}}

5).總結

  • 狀態轉移思想。

試題鏈接:

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/162937.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/162937.shtml
英文地址,請注明出處:http://en.pswp.cn/news/162937.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PTA-使用函數求最大公約數

本題要求實現一個計算兩個數的最大公約數的簡單函數。 函數接口定義&#xff1a; int gcd( int x, int y ); 其中x和y是兩個正整數&#xff0c;函數gcd應返回這兩個數的最大公約數。 裁判測試程序樣例&#xff1a; #include <stdio.h> int gcd( int x, int y ); i…

【數據結構】深入淺出理解鏈表中二級指針的應用

&#x1f984;個人主頁:修修修也 &#x1f38f;所屬專欄:數據結構 ??操作環境:Visual Studio 2022 (注:為方便演示本篇使用的x86系統,因此指針的大小為4個字節) 目錄 &#x1f4cc;形參的改變不影響實參! 1.調用函數更改整型時傳值調用與傳址調用的區別 &#x1f38f;傳值…

render函數舉例

在這段代碼中&#xff0c;renderButton是一個對象嗎 還有render為什么不能寫成render() {} 代碼原文鏈接 <template><div><renderButton /></div> </template><script setup> import { h, ref } from "vue"; const renderButt…

C#,簡單修改Visual Studio 2022設置以支持C#最新版本的編譯器,尊享編程之趣

1 PLS README & CHAPTER 5 用一個超簡單的例子說明各版本 C# 的差異。 使用新版本&#xff08;比如C#.11&#xff09;&#xff0c;當然有一定的好處。我們在寫程序的時候一般這樣&#xff1a; Visual Studio 2022 默認只能這樣寫&#xff1a; string imageFile Path.C…

若依框架參數驗證

文章目錄 一、前端觸發參數校驗異常1.前端頁面2.前端代碼 二、后端觸發參數校驗異常1.前端頁面2.后端報錯 三、后端自定義參數驗證1.添加注解2.觸發后端校驗 一、前端觸發參數校驗異常 1.前端頁面 輸入不符合校驗規則的值來觸發 2.前端代碼 校驗規則數組 表單的元素 修…

SQL Server數據庫備份與還原

目錄 SQL Server DataBase備份 SQL Server DataBase還原 SQL Server DataBase備份 在 SQL Server 中&#xff0c;你可以使用 SQL Server Management Studio (SSMS) 或 Transact-SQL 語句來手動備份數據庫。以下是兩種方法&#xff1a; 使用 SQL Server Management Studio (SS…

JAVA小游戲“飛翔的小鳥”

第一步是創建項目 項目名自擬 第二步創建個包名 來規范class 再創建一個包 來存儲照片 如下&#xff1a; 代碼如下&#xff1a; package game; import java.awt.*; import javax.swing.*; import javax.imageio.ImageIO;public class Bird {Image image;int x,y;int width…

Windows下安裝Anaconda3并使用JupyterNoteBook

下載安裝包 Anaconda官網 進官網&#xff0c;點擊下載 自動根據當前系統下載對應的包了&#xff0c;安裝包大約1G&#xff0c;喝杯Java耐心等待。 安裝 很多人安裝C盤&#xff0c;我這里放D盤。 注意&#xff1a;你的文件夾目錄一定要不能有空格 然后其他的直接默認install即…

不同路徑 遞歸

int dfs(int i, int j, int m, int n) { if (i > m || j > n) return 0; // 越界了 if (i m && j n) return 1; // 找到一種方法&#xff0c;相當于找到了葉子節點 return dfs(i 1, j, m, n) dfs(i, j 1, m, n); } int u…

在線視頻課程教育系統源碼/網課網校/知識付費/在線教育系統/在線課程培訓系統源碼

源碼簡介&#xff1a; 在線視頻課程教育系統源碼&#xff0c;作為網課/網校/知識付費/在線教育系統&#xff0c;它有文章付費閱讀在線點播自動發貨付費閱讀VIP會員系統等功能。它是實用的在線課程培訓系統源碼。 發貨100-在線視頻課程教育系統&#xff0c;它是一款功能實用的…

優思學院|2024年質量管理的大趨勢

2023年我們已經順利度過了整年的大部分時間&#xff0c;2024年質量管理的趨勢和問題在全球范圍內都已經引起了關注&#xff0c;或者仍然是企業導航的首要任務。 1. 通貨膨脹與質量管理 2023年&#xff0c;全球范圍內通貨膨脹和嚴峻的經濟狀況成為企業最關心的問題之一。盡管物…

Flash可更換聲音語音芯片WT588F02系列:優勢盡顯,應用廣泛

在語音技術日益普及的今天&#xff0c;唯創知音推出的Flash可更換聲音語音芯片WT588F02系列備受關注。該系列芯片憑借其強大的性能與廣泛的應用領域&#xff0c;成為市場上的一顆璀璨明星。本文將分析WT588F02系列的優勢&#xff0c;并探討其應用場景&#xff0c;以展現其在語音…

typedef 的使用

typedef 的定義 typedef 是 C 和 C 中的一個關鍵字&#xff0c;用于給已有類型定義一個新的名字&#xff0c;與 class、struct、union 和 enum 聲明不同&#xff0c;typedef 聲明不引入新類型&#xff1b;它們引入現有類型的新名稱 typedef 的語法格式 typedef existing_typ…

gitlab 12升級14(解決各種報錯問題)

1.這里是從自己公司的源下載的rpm包&#xff0c;需要換成自己的 2.從12的最后一個版本升級到14的最后一個版本 # 停服務 [rootdocker test]# gitlab-ctl stop puma && gitlab-ctl stop sidekiq && gitlab-ctl stop nginx && gitlab-ctl status# 進入…

前端如何判空

這樣判空就會報錯 loadNode(node, resolve)console.log("node")console.log(node)if (node.data ! null) {this.get(ctx /publicity/publicityType/typeTreeData?id node.data.id).then((res) > {resolve(res)})}}, 需要這樣寫&#xff0c;用typeof來做類型判…

【webrtc】ModuleRtpRtcpImpl2: RtpRtcp DEPRECATED_Create 廢棄了

基于m98 代碼。Deprecate the static RtpRtcp::Create() method. 提交記錄RtpRtcp::Create factory method 工廠方法廢棄了。std::unique_ptr<RtpRtcp> RtpRtcp::DEPRECATED_Create(const Configuration& configuration) {RTC_DCHECK

java 實現發送郵箱,復制即用,包含郵箱設置第三方登錄授權碼獲取方法

application.yml spring:profiles:active: dev # active: test#郵件附件上傳文件大小限制servlet:multipart:max-file-size: 50MB #單個文件大小限制max-request-size: 100MB #總文件大小限制&#xff08;允許存儲文件的文件夾大小&#xff09;mail:default-encoding: UTF…

【開題報告】基于SpringBoot的機車模型交流平臺的設計與實現

1.研究背景 機車模型是一種受到廣泛關注的模型制作愛好&#xff0c;它涵蓋了機車模型的收藏、展示、制作等多個方面。然而&#xff0c;由于機車模型愛好者的數量較少&#xff0c;且分散在不同的地區和社區&#xff0c;導致他們難以進行互動和資源共享。因此&#xff0c;需要一…

COBOL排序問題

*SORT排序文件文件超長&#xff0c;將主鍵保存在臨時文件里&#xff0c;超長的數據從數組里面去檢索獲取。 IDENTIFICATION DIVISION. PROGRAM-ID. TEST002. * ENVIRONMENT DIVISION. CONFIGURATION SECTION. …

YOLOv5改進: Inner-IoU基于輔助邊框的IoU損失,高效結合 GIoU, DIoU, CIoU,SIoU 等 | 2023.11

??????本文獨家改進:Inner-IoU引入尺度因子 ratio 控制輔助邊框的尺度大小用于計算損失,并與現有的基于 IoU ( GIoU, DIoU, CIoU,SIoU )損失進行有效結合 推薦指數:5顆星 新穎指數:5顆星 ??????Yolov5/Yolov7魔術師,獨家首發創新(原創),適用于…