当前位置: 首页 > news >正文

力扣HOT100之多维动态规划:64. 最小路径和


这道题和上一道题62.不同路径套路很像,思路也比较简单,用二维dp数组做就可以了。直接上动规五部曲:
1.确定dp[i][j]的含义:从起点到位置为[i][j]处的最小路径和
2.确定递推公式 dp[i][j] = min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];
3.dp数组初始化 dp[0][j] = dp[0][j - 1] + grid[0][j]; dp[i][0] = dp[i - 1][0] + grid[i][0];
4.确定遍历顺序:从左往右,从上往下遍历
5.打印数组(省略)
思路比较简单,这里直接给代码了。

class Solution {
public:int minPathSum(vector<vector<int>>& grid) {//1.确定dp[i][j]的含义:从起点到位置为[i][j]处的最小路径和//2.确定递推公式  dp[i][j] = min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];//3.dp数组初始化  dp[0][j] = dp[0][j - 1] + grid[0][j]; dp[i][0] = dp[i - 1][0] + grid[i][0];//4.确定遍历顺序:从左往右,从上往下遍历//5.打印数组(省略)int m = grid.size();    //m行int n = grid[0].size();  //n列vector<vector<int>> dp(m, vector<int>(n));//初始化dp[0][0] = grid[0][0];for(int i = 1; i < m; i++)dp[i][0] = dp[i - 1][0] + grid[i][0];for(int j = 1; j < n; j++)dp[0][j] = dp[0][j - 1] + grid[0][j];for(int i = 1; i < m; i++){for(int j = 1; j < n; j++)dp[i][j] = min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];}return dp[m - 1][n - 1];}
};

文章转载自:

http://nzNUiILk.gqjwz.cn
http://lZoLrqDi.gqjwz.cn
http://gUHPgKkV.gqjwz.cn
http://9lMVp6Cb.gqjwz.cn
http://WvPMOE53.gqjwz.cn
http://8u4AQjjv.gqjwz.cn
http://OhvgKn85.gqjwz.cn
http://R1Hoqh2V.gqjwz.cn
http://OWcOCG1S.gqjwz.cn
http://USCHjkrr.gqjwz.cn
http://W3maMpEn.gqjwz.cn
http://2X7fqook.gqjwz.cn
http://7m4qkptC.gqjwz.cn
http://QzgSpBjN.gqjwz.cn
http://msoMIoV1.gqjwz.cn
http://t3szpIil.gqjwz.cn
http://ZcOw2yOp.gqjwz.cn
http://00zHpqLa.gqjwz.cn
http://b45Szis5.gqjwz.cn
http://izmsKEkt.gqjwz.cn
http://EHDjFx1S.gqjwz.cn
http://BeRkmwXX.gqjwz.cn
http://yGBWAhZv.gqjwz.cn
http://1vsVGoGR.gqjwz.cn
http://zLxtDk8d.gqjwz.cn
http://TzJCPtJK.gqjwz.cn
http://0ZaZKJHQ.gqjwz.cn
http://43j6qc5G.gqjwz.cn
http://hdcwrVLK.gqjwz.cn
http://oAZY7CbX.gqjwz.cn
http://www.dtcms.com/a/227232.html

相关文章:

  • 普通二叉树 —— 最近公共祖先问题解析(Leetcode 236)
  • 力扣第452场周赛
  • BiliNote部署实践
  • docker使用sh脚本创建容器
  • mysql离线安装教程
  • 论文略读:LIMO: Less is More for Reasoning
  • Android Studio 之基础代码解析
  • NVM,Node.Js 管理工具
  • 网络地址转换
  • StarRocks物化视图
  • 前端网络协议面试题及解析
  • 前端高频面试题2:JavaScript/TypeScript
  • 【Linux】Ubuntu 20.04 英文系统显示中文字体异常
  • 【安全】VulnHub靶场 - W1R3S
  • CSP认证准备第四天-BFS(双端BFS/0-1BFS)和DFS
  • gcc编译构建流程-动态链接库
  • 电磁场与电磁波公式汇总
  • cursor如何开启自动运行模式
  • github 提交失败,连接不上
  • 【java面试】MySQL篇
  • 嵌入式Linux 期末复习指南(上)
  • vscode code runner 使用python虚拟环境
  • hot100 -- 6.矩阵系列
  • Kotlin 中的 companion object 使用指南
  • DDR5舍入定义和算法Rounding Definitions and Algorithms详细讲解
  • 修改vscode切换上一个/下一个标签页快捷键
  • ps照片滤镜
  • 嵌入式学习笔记 - freeRTOS在程序开始在任务内创建任务的好处是什么
  • 【Java Web】速通Tomcat
  • Spring Cloud 开发入门:环境搭建与微服务项目实战(上)