牛客热题:矩阵的最小路径和

📟作者主页:慢热的陕西人

🌴专栏链接:力扣刷题日记

📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言

文章目录

牛客热题:矩阵的最小路径和

题目链接

矩阵的最小路径和_牛客题霸_牛客网 (nowcoder.com)

方法一:二维dp

思路

①状态表示:

​ d p i j dpij dpij 表示为从起点(0, 0)到(i, j)位置的最小路径和

②初始化:

​ 首先对于第一行第一列来说,他们的路径都只有一条,就是从他们的上方或者左方到达,因此我们可以直接计算出他们的路径和。

③状态转移方程:

​ 对于每一个位置来说,有两个路径来源,我们选取路径和小的就可以。

​ d p i j = m i n ( d p i − 1 j , d p i j − 1 ) + m a t r i x i j dpij = min(dpi - 1j, dpij - 1) + matrixij dpij=min(dpi−1j,dpij−1)+matrixij

④填表顺序:

​ 我们发现当前位置状态的获取都需要依赖上方和左方位置的状态,因此我们填表顺序为:

从上到下,从左到右。

⑤返回结果:

​ 因为答案要求的是从起点到终点的最小路径和,因此我们要返回的结果就是 d p m − 1 n − 1 dpm - 1n - 1 dpm−1n−1

代码

cpp 复制代码
int minPathSum(vector<vector<int> >& matrix) 
    {
        int m = matrix.size();
        int n = matrix[0].size();
        vector<vector<int>> dp(m, vector<int>(n, 0));
        //初始化
        dp[0][0] = matrix[0][0];
        for(int i = 1; i < m || i < n; ++i)
        {
            if(i < m) dp[i][0] = dp[i - 1][0] + matrix[i][0];
            if(i < n) dp[0][i] = dp[0][i - 1] + matrix[0][i];
        }

        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]) + matrix[i][j];
            }
        return dp[m - 1][n - 1];
    }

复杂度

时间复杂度:遍历了一次二维dp数组: O ( m ∗ n ) O(m * n) O(m∗n)

空间复杂度:使用了额外的二维数组: O ( m ∗ n ) O(m * n) O(m∗n)

相关推荐
CSharp精选营4 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假7 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠8 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦15 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠16 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾16 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82116 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q16 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒16 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记16 天前
单项不带头不循环链表
数据结构·链表