forked from kamyu104/LeetCode-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlongest-increasing-path-in-a-matrix.py
79 lines (72 loc) · 2.63 KB
/
longest-increasing-path-in-a-matrix.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# Time: O(m * n)
# Space: O(m * n)
# topological sort solution
class Solution(object):
def longestIncreasingPath(self, matrix):
"""
:type matrix: List[List[int]]
:rtype: int
"""
directions = [(0, -1), (0, 1), (-1, 0), (1, 0)]
if not matrix:
return 0
in_degree = [[0]*len(matrix[0]) for _ in xrange(len(matrix))]
for i in xrange(len(matrix)):
for j in xrange(len(matrix[0])):
for di, dj in directions:
ni, nj = i+di, j+dj
if not (0 <= ni < len(matrix) and
0 <= nj < len(matrix[0]) and
matrix[ni][nj] > matrix[i][j]):
continue
in_degree[i][j] += 1
q = []
for i in xrange(len(matrix)):
for j in xrange(len(matrix[0])):
if not in_degree[i][j]:
q.append((i, j))
result = 0
while q:
new_q = []
for i, j in q:
for di, dj in directions:
ni, nj = i+di, j+dj
if not (0 <= ni < len(matrix) and
0 <= nj < len(matrix[0]) and
matrix[i][j] > matrix[ni][nj]):
continue
in_degree[ni][nj] -= 1
if not in_degree[ni][nj]:
new_q.append((ni, nj))
q = new_q
result += 1
return result
# Time: O(m * n)
# Space: O(m * n)
# dfs + memoization solution
class Solution2(object):
def longestIncreasingPath(self, matrix):
"""
:type matrix: List[List[int]]
:rtype: int
"""
directions = [(0, -1), (0, 1), (-1, 0), (1, 0)]
def longestpath(matrix, i, j, max_lengths):
if max_lengths[i][j]:
return max_lengths[i][j]
max_depth = 0
for di, dj in directions:
x, y = i+di, j+dj
if 0 <= x < len(matrix) and 0 <= y < len(matrix[0]) and \
matrix[x][y] < matrix[i][j]:
max_depth = max(max_depth, longestpath(matrix, x, y, max_lengths))
max_lengths[i][j] = max_depth + 1
return max_lengths[i][j]
if not matrix:
return 0
result = 0
max_lengths = [[0 for _ in xrange(len(matrix[0]))] for _ in xrange(len(matrix))]
for i in xrange(len(matrix)):
for j in xrange(len(matrix[0])):
result = max(result, longestpath(matrix, i, j, max_lengths))
return result