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

力扣 最小路径和

又是一道动态规划基础例题。

题目

这道题可以类似不同路径。先把左上角格子进行填充,然后用一个数组去更新每走到一个格的数字总和,首先处理边界问题,把最左边的列只能由上方的行与原来的格子数值的和,同理,最上方的行只能由作左边的行与原来的格子数值的和,然后像上次路径dp那样做遍历,直到取出右下角的坐标的数值即可。

class Solution {
     public int minPathSum(int[][] grid) {
        // f[m][n] = Math.min(f[m-1][n],f[m][n-1]) + grid[m][n]

        int m = grid.length ;
        int n = grid[0].length;
        int[][] dp = new int[m][n];
        dp[0][0] = grid[0][0];
        for ( int i = 1 ; i < m ; i++ ) {
            dp[i][0] = grid[i][0]+dp[i-1][0];
        }

        for ( int i = 1 ; i < n ; i++ ) {
            dp[0][i] = grid[0][i] + dp[0][i-1];
        }

        for ( int i = 1 ;  i < m ;  i++ ) {
            for ( int j = 1 ; j < n ; j++ ) {
                dp[i][j] = grid[i][j] + Math.min(dp[i-1][j],dp[i][j-1]);
            }
        }
        return dp[m-1][n-1];
    }
}

也可以优化成滚动数组。

class Solution {
    public int minPathSum(int[][] grid) {
        if (grid == null || grid.length == 0 || grid[0].length == 0) {
            return 0;
        }
        
        int rows = grid.length, columns = grid[0].length;
        
        // 创建一个一维数组 dp 来存储每一行的路径和
        int[] dp = new int[columns];
        
        dp[0] = grid[0][0]; // 起点处的最小路径和
        
        for (int j = 1; j < columns; j++) {
            dp[j] = dp[j - 1] + grid[0][j];
        }
        
        for (int i = 1; i < rows; i++) {
            // 第一列的位置,路径只能从上方来
            dp[0] += grid[i][0];
            
            for (int j = 1; j < columns; j++) {
                dp[j] = Math.min(dp[j], dp[j - 1]) + grid[i][j];
            }
        }
        
        // 最终的结果在 dp[columns - 1] 中,表示右下角的最小路径和
        return dp[columns - 1];
    }
}

典型路径动态规划,助你找准最好的路径。 


http://www.kler.cn/a/399640.html

相关文章:

  • 面试经典 150 题:20、2、228、122
  • Python Excel XLS或XLSX转PDF详解:七大实用转换设置
  • 机器学习-37-对ML的思考之机器学习发展的三个阶段和驱动AI发展三驾马车的由来
  • springboot企业级项目常用的pom依赖
  • python 多进程,程序运行越来越慢踩坑
  • 大数据新视界 -- 大数据大厂之 Impala 性能飞跃:分区修剪优化的应用案例(下)(22 / 30)
  • Hyper-v中ubuntu与windows文件共享
  • ML 系列: 第 23 节 — 离散概率分布 (多项式分布)
  • SpringBoot开发——整合 apache fileupload 轻松实现文件上传与下载
  • Freemarker模板 jar!/BOOT-INF/classes!/**.html
  • 编译安卓SDK时出现:600:26 test android/soong/ui/build/paths的解决方案
  • Swift 宏(Macro)入门趣谈(二)
  • 【网络安全】记一次APP登录爆破
  • 抖音热门素材去哪找?优质抖音视频素材网站推荐!
  • Flutter网络通信-封装Dio
  • 网络安全:数字时代的护城河
  • 机器学习笔记2 - 机器学习的一般流程
  • Unity-Editor扩展Odin + 自定义EditorWindow记录
  • Python正则表达式中re.M 是什么意思
  • Big Data for AI实践:面向AI大模型开发和应用的大规模数据处理套件
  • 【WPF】Prism学习(四)
  • 深入浅出 Go 语言:现代编程的高效选择
  • 【PGCCC】Postgresql 存储设计
  • Flink运行时架构以及核心概念
  • 基于SpringBoot+Vue的船舶维保管理系统(带1w+文档)
  • UE5的线程同步机制