-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathminimum-time-takes-to-reach-destination-without-drowning.py
69 lines (66 loc) · 2.9 KB
/
minimum-time-takes-to-reach-destination-without-drowning.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
# Time: O(m * n)
# Space: O(m * n)
# simulation, bfs
class Solution(object):
def minimumSeconds(self, land):
"""
:type land: List[List[str]]
:rtype: int
"""
DIRECTIONS = ((1, 0), (0, 1), (-1, 0), (0, -1))
lookup = [[-1 if land[i][j] == "*" else 0 for j in xrange(len(land[0]))] for i in xrange(len(land))]
q = [(i, j, -1) for i in xrange(len(land)) for j in xrange(len(land[0])) if land[i][j] == "*"]
q.append(next((i, j, 1) for i in xrange(len(land)) for j in xrange(len(land[0])) if land[i][j] == "S"))
lookup[q[-1][0]][q[-1][1]] = 1
while q:
new_q = []
for i, j, d in q:
if land[i][j] == "D":
return d-1
for di, dj in DIRECTIONS:
ni, nj = i+di, j+dj
if not (0 <= ni < len(land) and 0 <= nj < len(land[0]) and land[ni][nj] != "X" and lookup[ni][nj] != -1):
continue
if d != -1 and lookup[ni][nj] == 0:
lookup[ni][nj] = 1
new_q.append((ni, nj, d+1))
elif d == -1 and land[ni][nj] != "D":
lookup[ni][nj] = -1
new_q.append((ni, nj, -1))
q = new_q
return -1
# Time: O(m * n)
# Space: O(m * n)
# simulation, bfs
class Solution2(object):
def minimumSeconds(self, land):
"""
:type land: List[List[str]]
:rtype: int
"""
DIRECTIONS = ((1, 0), (0, 1), (-1, 0), (0, -1))
lookup1 = [[0 if land[i][j] == "*" else -1 for j in xrange(len(land[0]))] for i in xrange(len(land))]
lookup2 = [[-1]*len(land[0]) for _ in xrange(len(land))]
q1 = [(i, j) for i in xrange(len(land)) for j in xrange(len(land[0])) if land[i][j] == "*"]
q2 = [next((i, j) for i in xrange(len(land)) for j in xrange(len(land[0])) if land[i][j] == "S")]
lookup2[q2[0][0]][q2[0][1]] = 0
while q1 or q2:
new_q1, new_q2 = [], []
for i, j in q1:
for di, dj in DIRECTIONS:
ni, nj = i+di, j+dj
if not (0 <= ni < len(land) and 0 <= nj < len(land[0]) and land[ni][nj] != "X" and land[ni][nj] != "D" and lookup1[ni][nj] == -1):
continue
lookup1[ni][nj] = 0
new_q1.append((ni, nj))
for i, j in q2:
if land[i][j] == "D":
return lookup2[i][j]
for di, dj in DIRECTIONS:
ni, nj = i+di, j+dj
if not (0 <= ni < len(land) and 0 <= nj < len(land[0]) and land[ni][nj] != "X" and lookup2[ni][nj] == lookup1[ni][nj] == -1):
continue
lookup2[ni][nj] = lookup2[i][j]+1
new_q2.append((ni, nj))
q1, q2 = new_q1, new_q2
return -1