欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 国际 > Golang | Leetcode Golang题解之第329题矩阵中的最长递增路径

Golang | Leetcode Golang题解之第329题矩阵中的最长递增路径

2026/6/2 18:32:07 来源:https://blog.csdn.net/weixin_66442839/article/details/141005903  浏览:    关键词:Golang | Leetcode Golang题解之第329题矩阵中的最长递增路径

题目:

题解:

var (dirs = [][]int{[]int{-1, 0}, []int{1, 0}, []int{0, -1}, []int{0, 1}}rows, columns int
)func longestIncreasingPath(matrix [][]int) int {if len(matrix) == 0 || len(matrix[0]) == 0 {return 0}rows, columns = len(matrix), len(matrix[0])outdegrees := make([][]int, rows)for i := 0; i < rows; i++ {outdegrees[i] = make([]int, columns)}for i := 0; i < rows; i++ {for j := 0; j < columns; j++ {for _, dir := range dirs {newRow, newColumn := i + dir[0], j + dir[1]if newRow >= 0 && newRow < rows && newColumn >= 0 && newColumn < columns && matrix[newRow][newColumn] > matrix[i][j] {outdegrees[i][j]++}}}}queue := [][]int{}for i := 0; i < rows; i++ {for j := 0; j < columns; j++ {if outdegrees[i][j] == 0 {queue = append(queue, []int{i, j})}}}ans := 0for len(queue) != 0 {ans++size := len(queue)for i := 0; i < size; i++ {cell := queue[0]queue = queue[1:]row, column := cell[0], cell[1]for _, dir := range dirs {newRow, newColumn := row + dir[0], column + dir[1]if newRow >= 0 && newRow < rows && newColumn >= 0 && newColumn < columns && matrix[newRow][newColumn] < matrix[row][column] {outdegrees[newRow][newColumn]--if outdegrees[newRow][newColumn] == 0 {queue = append(queue, []int{newRow, newColumn})}}}}}return ans
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词