【每天学习一点算法 2026/05/25】矩阵中的最长递增路径

每天学习一点算法 2026/05/25

题目:矩阵中的最长递增路径

给定一个 m x n 整数矩阵 matrix ,找出其中 最长递增路径 的长度。

对于每个单元格,你可以往上,下,左,右四个方向移动。 你 不能 在 对角线 方向上移动或移动到 边界外(即不允许环绕)。

这个题的思路还是很简单的,只需要以每个单元格作为起点遍历出所有的递增路径取出最长的就是整个矩阵中最长的递增路径,但是这个过程肯定会有重复的,我们可以采取一些措施减少重复遍历。

我们需要记录每个已遍历单元格作为起点的的最长递增路径长度,我们可以直接利用深度优先遍历,回归时记录每个单元格的最长路径。记录方法最容易想到的就是map,我们也可以将原单元格替换成一个二维数组用于记录当前数字和最长递增路径长度,这样同样可以实现记录的功能。

typescript 复制代码
function longestIncreasingPath(matrix: (number | number [])[][]): number {
  let res = 0 // 用于存储最长路径长度
  const m = matrix.length
  const n = matrix[0].length
  // 遍历网格元素
  for (let i = 0; i < m; i++) {
    for (let j = 0; j < n; j++) {
      // 如果单元格元素是数组表示已经遍历过了,直接跳过
      if (Array.isArray(matrix[i][j])) continue
      const len = dfs(i, j, null) // 调用深度优先遍历方法获取当前元素作为起点最长路径长度
      res = Math.max(res, len) // 对比存储最大值
    }
  }

  return res // 返回最长路径长度

  // 深度优先遍历辅助函数
  function dfs (i: number, j: number, prev: number | null) {
    if (i < 0 || j < 0 || i >= m || j >= n) return 0 // 超出边界直接返回 0
    const current = matrix[i][j] // 当前单元格元素
    // 如果元素是数组,表示已经遍历过
    if (Array.isArray(current)) {
      // 如果数字大于当前上一个单元格数组返回它的最长路径长度,否则返回 0
      return current[0] <= prev ? 0 : current[1]
    }
    
    // 如果元素是数字,未遍历过
    if (prev !== null && current <= prev) return 0 // 如果小于上个数字返回 0
    // 递归上下左右方向
    const top = dfs(i - 1, j, current)
    const bottom = dfs(i + 1, j, current)
    const left = dfs(i, j - 1, current)
    const right = dfs(i, j + 1, current)
    // 获得各个方向中的最长路径加一就是当前的最长路径
    const max = Math.max(top, bottom, left, right) + 1
    // 存储并返回当前元素的最长路径
    matrix[i][j] = [current, max]
    return max
  }
};

题目来源:力扣(LeetCode)

相关推荐
oo哦哦8 小时前
轻量化内容中台如何破解企业矩阵运营困局?以星链引擎为例的技术解析
大数据·人工智能·矩阵
wuxinyan1239 小时前
工业级大模型学习之路021:LangChain零基础入门教程(第四篇):文档加载与文本分块技术
人工智能·python·学习·langchain
oo哦哦9 小时前
企业级矩阵管理中台:从“人海战术“到“AI智能增长“的架构演进与实践解析
人工智能·矩阵·架构·轻量化中台
Qres8219 小时前
Git基础命令学习笔记
笔记·git·学习
叁散9 小时前
实验报告:5G 仿真环境与基本链路模拟
算法
奔跑的Ma~9 小时前
Azure OpenAI Codex 详细配置与使用教程(国内用户专属)
学习·microsoft·flask·ai编程·azure
从负无穷开始的三次元代码生活9 小时前
算法零碎灵感点分享
算法
染指111010 小时前
9.LangChain框架(实现RAG)
数据库·人工智能·算法·机器学习·ai·大模型
大数据三康10 小时前
在spyder进行的遗传算法练习
开发语言·python·算法