【每天学习一点算法 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)

相关推荐
通信小呆呆11 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
Bobolink_11 小时前
TikTok矩阵账号如何批量养号?工作室级运营方案分享
矩阵·内容运营·跨境电商·tik tok·账号运营
H__Rick11 小时前
自动对焦学习-3
人工智能·学习·计算机视觉
benben04411 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
Daisy Lee12 小时前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn8612 小时前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e13 小时前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
何以解忧,唯有..13 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
小雨下雨的雨13 小时前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙