【LeetCode每日一题】——329.矩阵中的最长递增路径

一【题目类别】

  • 深度优先搜索

二【题目难度】

  • 困难

三【题目编号】

  • 329.矩阵中的最长递增路径

四【题目描述】

  • 给定一个 m x n 整数矩阵 matrix ,找出其中 最长递增路径 的长度。
  • 对于每个单元格,你可以往上,下,左,右四个方向移动。 你 不能 在 对角线 方向上移动或移动到 边界外(即不允许环绕)。

五【题目示例】

  • 示例 1:

    • 在这里插入图片描述
    • 输入:matrix = [[9,9,4],[6,6,8],[2,1,1]]
    • 输出:4
    • 解释:最长递增路径为 [1, 2, 6, 9]。
  • 示例 2:

    • 在这里插入图片描述
    • 输入:matrix = [[3,4,5],[3,2,6],[2,2,1]]
    • 输出:4
    • 解释:最长递增路径是 [3, 4, 5, 6]。注意不允许在对角线方向上移动。
  • 示例 3:

    • 输入:matrix = [[1]]
    • 输出:1

六【解题思路】

  • 利用记忆化深度优先搜索的思路
  • 使用一个二维数组,此二维数组大小与输入的二维数组大小相等,目的是保存每一个位置的最长路径长度
  • 然后按照【LeetCode每日一题】——695.岛屿的最大面积的思路进行深度优先搜索
  • 每次搜索都要去新建的二维数组中对比之前的路径长度,如果更长就需要更新
  • 而且,每次搜索的路径长度可能与新建的二维数组中保存的路径长度产生更长的路径长度
  • 这就是记忆化深度优先搜索,其实就是使用一个新的与原来二维数组一样大的二维数组将状态保存
  • 最后最长的路径长度即可

七【题目提示】

  • m = = m a t r i x . l e n g t h m == matrix.length m==matrix.length
  • n = = m a t r i x [ i ] . l e n g t h n == matrix[i].length n==matrix[i].length
  • 1 < = m , n < = 200 1 <= m, n <= 200 1<=m,n<=200
  • 0 < = m a t r i x [ i ] [ j ] < = 2 31 − 1 0 <= matrix[i][j] <= 2^{31} - 1 0<=matrix[i][j]<=2311

八【时间频度】

  • 时间复杂度: O ( m ∗ n ) O(m*n) O(mn),其中 m , n m,n m,n分别为传入的二维数组的行和列
  • 空间复杂度: O ( m ∗ n ) O(m*n) O(mn),其中 m , n m,n m,n分别为传入的二维数组的行和列

九【代码实现】

  1. Java语言版
class Solution {

    int[][] dirs = {{1,0},{0,1},{-1,0},{0,-1}};

    public int longestIncreasingPath(int[][] matrix) {
        int m = matrix.length;
        int n = matrix[0].length;
        int[][] temp = new int[m][n];
        int res = 0;
        for(int i = 0;i<m;i++){
            for(int j = 0;j<n;j++){
                if(temp[i][j] == 0){
                    res = Math.max(res,dfs(matrix,i,j,temp));
                }
            }
        }
        return res;
    }

    public int dfs(int[][] matrix,int i,int j,int[][] temp){
        if(temp[i][j] != 0){
            return temp[i][j];
        }
        int res = 1;
        for(int[] dir : dirs){
            int newRow = i + dir[0];
            int newCol = j + dir[1];
            if(newRow >= 0 && newRow < matrix.length && newCol >= 0 && newCol < matrix[0].length && matrix[newRow][newCol] > matrix[i][j]){
                res = Math.max(res,dfs(matrix,newRow,newCol,temp) + 1);
            }
        }
        temp[i][j] = res;
        return res;
    }

}
  1. C语言版
const int dirs[4][2] = {{1,0},{0,1},{-1,0},{0,-1}};

int dfs(int** matrix,int m,int n,int i, int j,int** temp)
{
    if(temp[i][j] != 0)
    {
        return temp[i][j];
    }
    temp[i][j]++;
    for(int k = 0;k<4;k++)
    {
        int newRow = i + dirs[k][0];
        int newCol = j + dirs[k][1];
        if(newRow >= 0 && newRow < m && newCol >= 0 && newCol < n && matrix[newRow][newCol] > matrix[i][j])
        {
            temp[i][j] = fmax(temp[i][j],dfs(matrix,m,n,newRow,newCol,temp) + 1);
        }
    }
    return temp[i][j];
}

int longestIncreasingPath(int** matrix, int matrixSize, int* matrixColSize)
{
    int m = matrixSize;
    int n = matrixColSize[0];
    int** temp = (int**)malloc(sizeof(int*) * m);
    for(int i = 0;i<m;i++)
    {
        temp[i] = (int*)calloc(n,sizeof(int));
    }
    int res = 0;
    for(int i = 0;i<m;i++)
    {
        for(int j = 0;j<n;j++)
        {
            res = fmax(res,dfs(matrix,m,n,i,j,temp));
        }
    }
    free(temp);
    return res;
}
  1. Python语言版
class Solution:
    def longestIncreasingPath(self, matrix: List[List[int]]) -> int:
        def dfs(x,y):
            if temp[x][y] != 0:
                return temp[x][y]
            temp[x][y] += 1
            for dx,dy in [(1,0),(0,1),(-1,0),(0,-1)]:
                newX = x + dx
                newY = y + dy
                if 0 <= newX < m and 0 <= newY < n and matrix[newX][newY] > matrix[x][y]:
                    temp[x][y] = max(temp[x][y],dfs(newX,newY) + 1)
            return temp[x][y]
        m = len(matrix)
        n = len(matrix[0])
        temp = [[0] * n for _ in range(m)]
        res = 0
        for i in range(m):
            for j in range(n):
                res = max(res,dfs(i,j))
        return res
  1. C++语言版
class Solution {
public:
    static constexpr int dirs[4][2] = {{1,0},{0,1},{-1,0},{0,-1}};

    int dfs(vector<vector<int>>& matrix,int m,int n,int x,int y,vector<vector<int>>& memo)
    {
        if(memo[x][y] != 0)
        {
            return memo[x][y];
        }
        memo[x][y]++;
        for(int i = 0;i<4;i++)
        {
            int newX = x + dirs[i][0];
            int newY = y + dirs[i][1];
            if(newX >= 0 && newX < m && newY >= 0 && newY < n && matrix[newX][newY] > matrix[x][y])
            {
                memo[x][y] = max(memo[x][y],dfs(matrix,m,n,newX,newY,memo) + 1);
            }
        }
        return memo[x][y];
    }

    int longestIncreasingPath(vector<vector<int>>& matrix) {
        int m = matrix.size();
        int n = matrix[0].size();
        auto memo = vector<vector<int>>(m,vector<int>(n));
        int res = 0;
        for(int i = 0;i<m;i++)
        {
            for(int j = 0;j<n;j++)
            {
                res = max(res,dfs(matrix,m,n,i,j,memo));
            }
        }
        return res;
    }
};

十【提交结果】

  1. Java语言版
    在这里插入图片描述

  2. C语言版
    在这里插入图片描述

  3. Python语言版
    在这里插入图片描述

  4. C++语言版
    在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IronmanJay

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值