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

LeetCode 64. 最小路径和(HOT100)

第一次错误代码: 

class Solution {
public:int minPathSum(vector<vector<int>>& grid) {int dp[205][205] = {0};int m = grid.size(),n = grid[0].size();for(int i = 1 ;i<=m;i++){for(int j = 1;j<=n;j++){dp[i][j] = min(dp[i][j-1],dp[i-1][j])+grid[i-1][j-1];}}return dp[m][n];}
};

正确代码:
 

class Solution {
public:int minPathSum(vector<vector<int>>& grid) {if(grid.size()==0)return 0;int m = grid.size(),n = grid[0].size();vector<vector<int>>dp(m,vector<int>(n,INT_MAX));dp[0][0]  = grid[0][0];//第一行for(int j = 1;j<n;j++){dp[0][j] = dp[0][j-1]+grid[0][j];}//第一列for(int j = 1;j<m;j++){dp[j][0] = dp[j-1][0]+grid[j][0];}//othersfor(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];        }
};

 

class Solution {
public:int minPathSum(vector<vector<int>>& grid) {if (!grid.size())return 0;int m = grid.size(), n = grid[0].size();vector<vector<int>> dp(m, vector<int>(n, INT_MAX));for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (!i && !j) {//[0][0]dp[0][0] = grid[0][0];} else if (!i) {//第一行dp[i][j] = dp[i][j - 1] + grid[i][j];} else if (!j) {//第二行dp[i][j] = dp[i - 1][j] + grid[i][j];} else {dp[i][j] = min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j];}}}return dp[m - 1][n - 1];}
};

空间优化:直接在grid数组上记录:

class Solution {
public:int minPathSum(vector<vector<int>>& grid) {int m = grid.size(),n = grid[0].size();for(int i = 0;i<m;i++){for(int j = 0;j<n;j++){if(!i&&!j)continue;if(!i)grid[i][j] +=grid[i][j-1];else if(!j)grid[i][j]+=grid[i-1][j];else grid[i][j]  = min(grid[i-1][j],grid[i][j-1])+grid[i][j];}}return grid[m-1][n-1];}
};

本题注意:第一列和第一行需要特殊处理,以为它们只能分别从上面 左边过来。

http://www.lryc.cn/news/496727.html

相关文章:

  • ESP8266作为TCP客户端或者服务器使用
  • C#结合.NET框架快速构建和部署AI应用
  • 题外话 (火影密令)
  • 蓝桥杯准备训练(lesson1,c++方向)
  • RTDETR融合[ECCV2024]WTConvNeXt中的WTConv模块及相关改进思路
  • AD7606使用方法
  • 嵌入式系统应用-LVGL的应用-平衡球游戏 part1
  • JVM(四) - JVM 内存结构
  • 【AI系统】CANN 算子类型
  • VUE脚手架练习
  • 动态艺术:用Python将文字融入GIF动画
  • 更多开源创新 挑战OpenAI-o1的模型出现和AI个体模拟突破
  • VR眼镜可视化编程:开启医疗信息系统新纪元
  • Ubuntu访问简书403
  • SQL高级应用——索引与视图
  • docker部署文件编写(还未尝试)
  • 缓存与数据库数据一致性 详解
  • 每日计划-1203
  • HTML5动漫主题网站——天空之城 10页 html+css+设计报告成品项目模版
  • 分布式会话 详解
  • 探索仓颉编程语言:官网上线,在线体验与版本下载全面启航
  • Ubuntu无法连接Linux
  • 【Spring】注解开发
  • 数字图像稳定DIS介绍目录
  • 【人工智能-基础】SVM中的核函数到底是什么
  • 字节青训Marscode——8:找出整形数组中超过一半的数
  • C++ 异步编程的利器std::future和std::promise
  • CRM 系统中的 **知识库功能** 的设计与实现
  • 重学设计模式-工厂模式(简单工厂模式,工厂方法模式,抽象工厂模式)
  • 【C语言】结构体(四)