Reverse Thinking¶
Table of Contents¶
- 2139. Minimum Moves to Reach Target Score (Medium)
- 1558. Minimum Numbers of Function Calls to Make Target Array (Medium)
- 554. Brick Wall (Medium)
- 2718. Sum of Matrix After Queries (Medium)
- 417. Pacific Atlantic Water Flow (Medium)
- 991. Broken Calculator (Medium)
- 2227. Encrypt and Decrypt Strings (Hard)
- 3419. Minimize the Maximum Edge Weight of Graph (Medium)
- 936. Stamping The Sequence (Hard)
2139. Minimum Moves to Reach Target Score¶
1558. Minimum Numbers of Function Calls to Make Target Array¶
554. Brick Wall¶
2718. Sum of Matrix After Queries¶
417. Pacific Atlantic Water Flow¶
from collections import deque
from typing import List
# DFS
def pacificAtlanticDFS(heights: List[List[int]]) -> List[List[int]]:
m, n = len(heights), len(heights[0])
pac, atl = set(), set()
directions = [(1, 0), (0, 1), (-1, 0), (0, -1)]
def dfs(r, c, visited, prev_height):
if (
r not in range(m)
or c not in range(n)
or heights[r][c] < prev_height
or (r, c) in visited
):
return None
visited.add((r, c))
height = heights[r][c]
for dr, dc in directions:
dfs(dr + r, dc + c, visited, height)
for c in range(n):
dfs(0, c, pac, heights[0][c])
dfs(m - 1, c, atl, heights[m - 1][c])
for r in range(m):
dfs(r, 0, pac, heights[r][0])
dfs(r, n - 1, atl, heights[r][n - 1])
return list(pac & atl)
# BFS
def pacificAtlanticBFS(heights: List[List[int]]) -> List[List[int]]:
m, n = len(heights), len(heights[0])
pac, atl = set(), set()
directions = [(1, 0), (-1, 0), (0, 1), (0, -1)]
def bfs(r, c, visited):
q = deque([(r, c)])
visited.add((r, c))
while q:
row, col = q.popleft()
for dr, dc in directions:
nr, nc = row + dr, col + dc
if (
nr in range(m)
and nc in range(n)
and heights[row][col] <= heights[nr][nc]
and (nr, nc) not in visited
):
q.append((nr, nc))
visited.add((nr, nc))
for c in range(n):
bfs(0, c, pac) # top
bfs(m - 1, c, atl) # bottom
for r in range(m):
bfs(r, 0, pac) # left
bfs(r, n - 1, atl) # right
return list(pac & atl)
heights = [
[1, 2, 2, 3, 5],
[3, 2, 3, 4, 4],
[2, 4, 5, 3, 1],
[6, 7, 1, 4, 5],
[5, 1, 1, 2, 4],
]
print(pacificAtlanticDFS(heights))
# [(4, 0), (0, 4), (3, 1), (1, 4), (3, 0), (2, 2), (1, 3)]
print(pacificAtlanticBFS(heights))
# [(4, 0), (0, 4), (3, 1), (1, 4), (3, 0), (2, 2), (1, 3)]
991. Broken Calculator¶
2227. Encrypt and Decrypt Strings¶
3419. Minimize the Maximum Edge Weight of Graph¶
-
Tags: Binary Search, Depth First Search, Breadth First Search, Graph, Shortest Path