python3 dic 排序_【LeeCode 困难 python3】329. 矩阵中的最长递增路径

点击蓝色“不太灵光的程序员”关注我哟

加个“星标”,每天上午 08:00,干货推送!

d9c119828609e2e31599786d7a4a9426.png

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

困难 深度优先搜索 拓扑排序 记忆化

给定一个整数矩阵,找出最长递增路径的长度。

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

示例 1:

输入: nums =
[
[ 9 ,9,4],
[ 6 ,6,8],
[ 2 , 1 ,1]
]
输出: 4
解释: 最长递增路径为 [1, 2, 6, 9]。

示例 2:

输入: nums =
[
[ 3 , 4 , 5 ],
[3,2, 6 ],
[2,2,1]
]
输出: 4 解释: 最长递增路径是 [3, 4, 5, 6]。注意不允许在对角线方向上移动。

解析

从左到右 从上到小遍历 dic 记录已经计算过的点,减少计算次数

from typing import List# 执行用时:544 ms, 在所有 Python3 提交中击败了64.30%的用户# 内存消耗:17.4 MB, 在所有 Python3 提交中击败了50.00%的用户class Solution:def longestIncreasingPath(self, matrix: List[List[int]]) -> int:if not matrix: return 0
m = len(matrix)
n = len(matrix[0])
dic = {}def get_next_node(i, j):
len1 = len2 = len3 = len4 = 1# 上if i - 1 >= 0 and matrix[i][j] < matrix[i - 1][j]:if (i - 1, j) in dic:
len1 = dic[(i - 1, j)]else:
len1 += get_next_node(i - 1, j)
dic[(i - 1, j)] = len1# 下if i + 1 < m and matrix[i][j] < matrix[i + 1][j]:if (i + 1, j) in dic:
len2 = dic[(i + 1, j)]else:
len2 += get_next_node(i + 1, j)
dic[(i + 1, j)] = len2# 左if j - 1 >= 0 and matrix[i][j] < matrix[i][j - 1]:if (i, j - 1) in dic:
len3 = dic[(i, j - 1)]else:
len3 += get_next_node(i, j - 1)
dic[(i, j - 1)] = len3# 右if j + 1 < n and matrix[i][j] < matrix[i][j + 1]:if (i, j + 1) in dic:
len4 = dic[(i, j + 1)]else:
len4 += get_next_node(i, j + 1)
dic[(i, j + 1)] = len4return max(len1, len2, len3, len4)
max_len = 0for i in range(m):for j in range(n):
lens = get_next_node(i, j)if lens > max_len:
max_len = lensreturn max_len
s = Solution()
nums = [[3, 4, 5],[3, 2, 6],[2, 2, 1]]
ret = s.longestIncreasingPath(nums)print(ret, ret == 4)
nums = [[9, 9, 4],[6, 6, 8],[2, 1, 1]]
ret = s.longestIncreasingPath(nums)print(ret, ret == 4)
nums = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],[19, 18, 17, 16, 15, 14, 13, 12, 11, 10],[20, 21, 22, 23, 24, 25, 26, 27, 28, 29],[39, 38, 37, 36, 35, 34, 33, 32, 31, 30],[40, 41, 42, 43, 44, 45, 46, 47, 48, 49],[59, 58, 57, 56, 55, 54, 53, 52, 51, 50],[60, 61, 62, 63, 64, 65, 66, 67, 68, 69],[79, 78, 77, 76, 75, 74, 73, 72, 71, 70],[80, 81, 82, 83, 84, 85, 86, 87, 88, 89],[99, 98, 97, 96, 95, 94, 93, 92, 91, 90],[100, 101, 102, 103, 104, 105, 106, 107, 108, 109],[119, 118, 117, 116, 115, 114, 113, 112, 111, 110],[120, 121, 122, 123, 124, 125, 126, 127, 128, 129],[139, 138, 137, 136, 135, 134, 133, 132, 131, 130],[0, 0, 0, 0, 0, 0, 0, 0, 0, 0]]
ret = s.longestIncreasingPath(nums)print(ret, ret == 4)

end

推荐阅读:
  • 让运维更简单的7种定时任务实现方式
  • 细品28岁程序员退休创业背后的可怕故事
  • Python行业就业现状
  • 基于Redis实现消息队列(上)
  • 基于Redis实现消息队列(中)
  • 基于Redis实现消息队列(下)
8b127c6f3cdcaff4db63ab1a9738312b.png 如有收获,点个在看,诚挚感谢 8e61981b08d65e5cc8521d70ef64200b.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值