2684. 矩阵中移动的最大次数

给你一个下标从 0 开始、大小为 m x n 的矩阵 grid ,矩阵由若干 正 整数组成。

你可以从矩阵第一列中的 任一 单元格出发,按以下方式遍历 grid : 从单元格 (row, col) 可以移动到 (row - 1, col + 1)、(row, col + 1) 和 (row + 1, col + 1) 三个单元格中任一满足值 严格 大于当前单元格的单元格。 返回你在矩阵中能够 移动 的 最大 次数。

示例 1:

输入:grid = [[2,4,3,5],[5,4,9,3],[3,4,2,11],[10,9,13,15]] 输出:3 解释:可以从单元格 (0, 0) 开始并且按下面的路径移动:

  • (0, 0) -> (0, 1).
  • (0, 1) -> (1, 2).
  • (1, 2) -> (2, 3).
    可以证明这是能够移动的最大次数。

示例 2:

输入:grid = [[3,2,4],[2,1,9],[1,1,7]] 输出:0 解释:从第一列的任一单元格开始都无法移动。

解题思路: @@@ dfs 解法

  • 遍历每一行的第一个单元格,以该单元格为起点进行深度优先搜索。
  • 在搜索过程中,递归地探索相邻单元格,并更新移动的最大次数。
  • 使用一个二维数组 visited 来记录已经访问过的单元格,避免重复访问。
  • 在搜索过程中,根据移动条件更新移动的最大次数 maxCount。
  • 返回最大移动次数 maxCount 作为结果。
func maxMoves(grid [][]int) int {
      m, n := len(grid), len(grid[0])
      
      maxCount := 0
      dirs := [][]int{{-1, 1}, {0, 1}, {1, 1}}
      
      var dfs func(i, j int, visited [][]bool) int
      dfs = func(i, j int, visited [][]bool) int {
          if i < 0 || i >= m || j < 0 || j >= n || visited[i][j] {
              return 0
          }
          visited[i][j] = true
          count := j
          for _, dir := range dirs {
              newi, newj := i+dir[0], j+dir[1]
              if newi >= 0 && newi < m && newj >= 0 && newj < n && grid[newi][newj] > grid[i][j] {
                  count = max(count, dfs(newi, newj, visited))
              }
          }
          return count
      }
      
      for i := 0; i < m; i++ {
          visited := make([][]bool, m)
          for j := range visited {
              visited[j] = make([]bool, n)
          }
          count := dfs(i, 0, visited)
          maxCount = max(maxCount, count)
      }
      return maxCount
  }
  
  func max(a, b int) int {
      if a > b {
          return a
      }
      return b
}

@@@