LeetCode 熱題 100 64. 最小路徑和

LeetCode 熱題 100 | 64. 最小路徑和

大家好,今天我們來解決一道經典的動態規劃問題——最小路徑和。這道題在 LeetCode 上被標記為中等難度,要求找到從網格的左上角到右下角的路徑,使得路徑上的數字總和為最小。


問題描述

給定一個包含非負整數的 m x n 網格 grid,請找出一條從左上角到右下角的路徑,使得路徑上的數字總和為最小。

示例 1:

輸入:grid = [[1,3,1],[1,5,1],[4,2,1]]
輸出:7
解釋:因為路徑 1→3→1→1→1 的總和最小。

示例 2:

輸入:grid = [[1,2,3],[4,5,6]]
輸出:12

提示:

  • m == grid.length
  • n == grid[i].length
  • 1 <= m, n <= 200
  • 0 <= grid[i][j] <= 200

解題思路

核心思想
  1. 動態規劃

    • 使用動態規劃(DP)來解決這個問題。
    • 定義 dp[i][j] 為從網格的左上角到達位置 (i, j) 的最小路徑和。
    • 狀態轉移方程為:
      [
      dp[i][j] = \min(dp[i-1][j], dp[i][j-1]) + grid[i][j]
      ]
      其中,dp[i-1][j] 表示從上方到達 (i, j) 的最小路徑和,dp[i][j-1] 表示從左方到達 (i, j) 的最小路徑和。
  2. 初始化

    • dp[0][0] = grid[0][0],因為從起點到起點的路徑和就是起點的值。
    • 第一行和第一列的所有位置只能從一個方向到達,因此初始化為累加值。
  3. 遍歷

    • 遍歷整個網格,根據狀態轉移方程更新 dp[i][j]

Python代碼實現

class Solution:def minPathSum(self, grid):m, n = len(grid), len(grid[0])dp = [[0] * n for _ in range(m)]dp[0][0] = grid[0][0]# 初始化第一行for j in range(1, n):dp[0][j] = dp[0][j-1] + grid[0][j]# 初始化第一列for i in range(1, m):dp[i][0] = dp[i-1][0] + grid[i][0]# 遍歷網格for i in range(1, m):for j in range(1, n):dp[i][j] = min(dp[i-1][j], dp[i][j-1]) + grid[i][j]return dp[m-1][n-1]

代碼解析

  1. 初始化

    • dp 數組初始化為一個 m x n 的二維列表,所有值初始化為 0。
    • dp[0][0] = grid[0][0],因為從起點到起點的路徑和就是起點的值。
    • 第一行和第一列的所有位置只能從一個方向到達,因此初始化為累加值。
  2. 狀態轉移

    • 遍歷從 (1, 1)(m-1, n-1) 的每個位置 (i, j)
    • 對于每個位置 (i, j),更新 dp[i][j]min(dp[i-1][j], dp[i][j-1]) + grid[i][j]
  3. 返回結果

    • 最終結果存儲在 dp[m-1][n-1] 中,表示從左上角到右下角的最小路徑和。

復雜度分析

  • 時間復雜度:O(m * n),其中 mn 分別是網格的行數和列數。需要遍歷整個網格。
  • 空間復雜度:O(m * n),使用了大小為 m x ndp 數組。

示例運行

示例 1
輸入:grid = [[1,3,1],[1,5,1],[4,2,1]]
輸出:7
解釋:因為路徑 1→3→1→1→1 的總和最小。
示例 2
輸入:grid = [[1,2,3],[4,5,6]]
輸出:12

總結

通過動態規劃的方法,我們可以高效地解決最小路徑和問題。狀態轉移方程 dp[i][j] = \min(dp[i-1][j], dp[i][j-1]) + grid[i][j] 確保了我們能夠找到從左上角到右下角的最小路徑和。希望這篇題解對大家有所幫助,如果有任何問題,歡迎在評論區留言討論!

關注我,獲取更多算法題解和編程技巧!

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

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

相關文章

JavaSE核心知識點02面向對象編程02-06(泛型)

&#x1f91f;致敬讀者 &#x1f7e9;感謝閱讀&#x1f7e6;笑口常開&#x1f7ea;生日快樂?早點睡覺 &#x1f4d8;博主相關 &#x1f7e7;博主信息&#x1f7e8;博客首頁&#x1f7eb;專欄推薦&#x1f7e5;活動信息 文章目錄 JavaSE核心知識點02面向對象編程02-06&#…

LVGL對象的盒子模型和樣式

文章目錄 &#x1f9f1; LVGL 對象盒子模型結構&#x1f50d; 組成部分說明&#x1f3ae; 示例代碼&#x1f4cc; 總結一句話 &#x1f9f1; 一、樣式的本質&#xff1a;lv_style_t 對象&#x1f3a8; 二、樣式應用的方式&#x1f9e9; 三、樣式屬性分類&#xff08;核心&#…

Github上如何準確地搜索開源項目

Github上如何準確地搜索開源項目&#xff1a; 因為尋找項目練手是最快速掌握技術的途徑&#xff0c;而Github上有最全最好的開源項目。 就像我的畢業設計“機器翻譯”就可以在Github上查找開源項目來參考。 以下搜索針對&#xff1a;項目名的關鍵詞&#xff0c;關注數限制&a…

正點原子IMX6U開發板移植Qt時出現亂碼

移植Qt時出現亂碼 1、前言2、問題3、總結 1、前言 記錄一下正點原子IMX6U開發板移植Qt時出現亂碼的解決方法&#xff0c;方便自己日后回顧&#xff0c;也可以給有需要的人提供幫助。 2、問題 用正點原子IMX6U開發板移植Qt時移植Qt后&#xff0c;sd卡里已經存儲了Qt的各種庫&…

python-django項目啟動尋找靜態頁面html順序

目錄結構 settings模塊 urls模塊 views模塊 1.settings文件下沒有DIR目錄,按照各app注冊順序尋找靜態頁面 啟動效果&#xff0c;直接返回注冊的app即app01下的templates文件夾下的html頁面 2.settings文件添加上DIR目錄 啟動效果&#xff0c;會優先去找項目下的templates文件…

MySQL索引詳解(上)(結構/分類/語法篇)

一、索引概述 索引本質是幫助MySQL高效獲取數據的排序數據結構&#xff08;類似書籍目錄&#xff09;&#xff0c;通過減少磁盤I/O次數提升查詢效率。其核心價值體現在大數據量場景下的快速定位能力&#xff0c;但同時帶來存儲和維護成本。 核心特點&#xff1a; 優點&#…

數據集-目標檢測系列- 煙霧 檢測數據集 smoke >> DataBall

數據集-目標檢測系列- 消防 濃煙 檢測數據集 smoke>> DataBall 數據集-目標檢測系列- 煙霧 檢測數據集 smoke &#xff1e;&#xff1e; DataBall * 相關項目 1&#xff09;數據集可視化項目&#xff1a;gitcode: https://gitcode.com/DataBall/DataBall-detections-10…

docker + K3S + Jenkins + Harbor自動化部署

最近公司在研究自動化部署的一套流程&#xff0c;下面記錄一下配置流程 需要提前準備好Jenkins Harbor Git(其他管理工具也可以) 我這里的打包編譯流程是Jenkins上配置打包任務-->自動到git目錄下找打包文件---->項目編譯后打鏡像包------>打完鏡像包將鏡像上傳到…

《用MATLAB玩轉游戲開發:從零開始打造你的數字樂園》基礎篇(2D圖形交互)-《打磚塊:向量反射與實時物理模擬》MATLAB教程

《用MATLAB玩轉游戲開發&#xff1a;從零開始打造你的數字樂園》基礎篇&#xff08;2D圖形交互&#xff09;-《打磚塊&#xff1a;向量反射與實時物理模擬》MATLAB教程 &#x1f3ae; 文章目錄 《用MATLAB玩轉游戲開發&#xff1a;從零開始打造你的數字樂園》基礎篇&#xff08…

Redisson 看門狗機制

何為看門狗 看門狗機制的主要作用是自動續期鎖&#xff0c;確保在節點完成任務之前&#xff0c;鎖不會過期。具體來說&#xff0c;當一個節點獲取到鎖后&#xff0c;看門狗會定期檢查該鎖的過期時間&#xff0c;并在必要時延長鎖的過期時間&#xff0c;確保節點可以順利完成任…

[架構之美]linux常見故障問題解決方案(十九)

[架構之美]linux下常見故障問題解決方案 一&#xff0c;文本文件忙 問題一&#xff1a;rootwh-VMware-Virtual-Platform:/home/hail# cp /root/containerd/bin/* /usr/bin/ cp: 無法創建普通文件 ‘/usr/bin/containerd’: 文本文件忙 在Linux系統中遇到“文本文件忙”錯誤時…

QT實現曲線圖縮放、拖拽以及框選放大

.h文件 protected: void saveAxisRange();void wheelEvent(QWheelEvent *event) override;void mousePressEvent(QMouseEvent *event) override;void mouseMoveEvent(QMouseEvent *event) override;void mouseReleaseEvent(QMouseEvent *event) override;private:QPoint m_…

【Pandas】pandas DataFrame corr

Pandas2.2 DataFrame Computations descriptive stats 方法描述DataFrame.abs()用于返回 DataFrame 中每個元素的絕對值DataFrame.all([axis, bool_only, skipna])用于判斷 DataFrame 中是否所有元素在指定軸上都為 TrueDataFrame.any(*[, axis, bool_only, skipna])用于判斷…

青藏高原七大河流源區徑流深、蒸散發數據集(TPRED)

時間分辨率 月空間分辨率 1km - 10km共享方式 開放獲取數據大小 83.27 MB數據時間范圍 1998-07-01 — 2017-12-31元數據更新時間 2024-07-22 數據集摘要 通過構建耦合積雪、凍土、冰川等冰凍圈水文物理過程的WEB-DHM模型&#xff08;Water and Energy Budget-based Distribute…

window環境下,如何通過USB接口控制打印機

雖然說大多數情況下&#xff0c;我們可以非常便利的通過打印機驅動來控制打印機&#xff0c;但還是有一些特殊情況&#xff0c;導致無法通過打印機驅動來完成我們預想的任務&#xff0c;比如&#xff0c;打印機只是一個系統設備中的一部分&#xff0c;需要協調其它設備一起工作…

CDGP數據治理主觀題評分標準與得分策略

1.數據模型題目評分標準 1)準確理解題目中所描述的業務邏輯和需求得[1分] 2)正確使用模型設計方法,使用信息工程、信息建模集成定義、巴克符號、陳氏符號等其中一種得[1分] 3)正確設計實體和屬性,題目中涉及的實體數量為25-30個,10個以內得[2分],10-20個得[3分],25個…

工業設計破局密碼:3D 可視化技術點燃產業升級引擎

3D可視化是一種將數據、信息或抽象概念以三維圖形、模型和動畫的形式呈現出來的技術。3D可視化技術通過構建三維數字孿生體&#xff0c;將設計思維轉化為可交互的虛擬原型&#xff0c;不僅打破了傳統二維設計的空間局限&#xff0c;更在效率、精度與用戶體驗層面開創了全新維度…

Qt中在子線程中刷新UI的方法

Qt中在子線程中刷新UI的方法 在Qt中UI界面并不是線程安全的&#xff0c;意味著在子線程中不能隨意操作UI界面組件&#xff08;比如按鈕、標簽&#xff09;等&#xff0c;如果強行操作這些組件有可能會導致程序崩潰。那么在Qt中如何在子線程中刷新UI控件呢&#xff1f; 兩種方…

為了摸魚和吃瓜,我開發了一個網站

平時上班真的比較累&#xff0c;摸魚和吃瓜還要跳轉多個平臺的話&#xff0c;就累上加累了。 所以做了一個聚合了全網主流平臺熱搜的網站。 目前市面上確實有很多這種網站了&#xff0c;所以目前最主要有兩點和他們不同&#xff1a; 給熱搜列表增加了配圖&#xff0c;刷的時候…

操作系統學習筆記第2章 (竟成)

第 2 章 進程管理 【考綱內容】 1.進程與線程&#xff1a; (1) 進程 / 線程的基本概念&#xff1b; (2) 進程 / 線程的狀態與轉換&#xff1b; (3) 線程的實現&#xff1a;內核支持的線程&#xff1b;線程庫支持的線程&#xff1b; (4) 進程與線程的組織與控制&#xff1b; (5)…