You are given a 2-D matrix board containing 'X' and 'O' characters.
If a continous, four-directionally connected group of 'O's is surrounded by 'X's, it is considered to be surrounded.
Change all surrounded regions of 'O's to 'X's and do so in-place by modifying the input board.
Example 1:
Input: board = [
["X","X","X","X"],
["X","O","O","X"],
["X","O","O","X"],
["X","X","X","O"]
]
Output: [
["X","X","X","X"],
["X","X","X","X"],
["X","X","X","X"],
["X","X","X","O"]
]Explanation: Note that regions that are on the border are not considered surrounded regions.
Constraints:
1 <= board.length, board[i].length <= 200board[i][j] is 'X' or 'O'.
You should aim for a solution with O(m * n) time and O(m * n) space, where m is the number of rows and n is the number of columns in the matrix.
We observe that we need to capture the regions that are not connected to the O's on the border of the matrix. This means there should be no path connecting the O's on the border to any O's in the region. Can you think of a way to check the region connected to these border O's?
We can use the Depth First Search (DFS) algorithm. Instead of checking the region connected to the border O's, we can reverse the approach and mark the regions that are reachable from the border O's. How would you implement this?
We run the DFS from every 'O' on the border of the matrix, visiting the neighboring cells that are equal to 'O' recursively and marking them as '#' to avoid revisiting. After completing all the DFS calls, we traverse the matrix again and capture the cells where matrix[i][j] == 'O', and unmark the cells back to 'O' where matrix[i][j] == '#'.
class Solution:
def solve(self, board: List[List[str]]) -> None:
ROWS, COLS = len(board), len(board[0])
def capture(r, c):
if (r < 0 or c < 0 or r == ROWS or
c == COLS or board[r][c] != "O"
):
return
board[r][c] = "T"
capture(r + 1, c)
capture(r - 1, c)
capture(r, c + 1)
capture(r, c - 1)
for r in range(ROWS):
if board[r][0] == "O":
capture(r, 0)
if board[r][COLS - 1] == "O":
capture(r, COLS - 1)
for c in range(COLS):
if board[0][c] == "O":
capture(0, c)
if board[ROWS - 1][c] == "O":
capture(ROWS - 1, c)
for r in range(ROWS):
for c in range(COLS):
if board[r][c] == "O":
board[r][c] = "X"
elif board[r][c] == "T":
board[r][c] = "O"Where is the number of rows and is the number of columns of the .
class Solution:
def solve(self, board: List[List[str]]) -> None:
ROWS, COLS = len(board), len(board[0])
directions = [(1, 0), (-1, 0), (0, 1), (0, -1)]
def capture():
q = deque()
for r in range(ROWS):
for c in range(COLS):
if (r == 0 or r == ROWS - 1 or
c == 0 or c == COLS - 1 and
board[r][c] == "O"
):
q.append((r, c))
while q:
r, c = q.popleft()
if board[r][c] == "O":
board[r][c] = "T"
for dr, dc in directions:
nr, nc = r + dr, c + dc
if 0 <= nr < ROWS and 0 <= nc < COLS:
q.append((nr, nc))
capture()
for r in range(ROWS):
for c in range(COLS):
if board[r][c] == "O":
board[r][c] = "X"
elif board[r][c] == "T":
board[r][c] = "O"Where is the number of rows and is the number of columns of the .
class DSU:
def __init__(self, n):
self.Parent = list(range(n + 1))
self.Size = [1] * (n + 1)
def find(self, node):
if self.Parent[node] != node:
self.Parent[node] = self.find(self.Parent[node])
return self.Parent[node]
def union(self, u, v):
pu = self.find(u)
pv = self.find(v)
if pu == pv:
return False
if self.Size[pu] >= self.Size[pv]:
self.Size[pu] += self.Size[pv]
self.Parent[pv] = pu
else:
self.Size[pv] += self.Size[pu]
self.Parent[pu] = pv
return True
def connected(self, u, v):
return self.find(u) == self.find(v)
class Solution:
def solve(self, board: List[List[str]]) -> None:
ROWS, COLS = len(board), len(board[0])
directions = [(1, 0), (-1, 0), (0, 1), (0, -1)]
dsu = DSU(ROWS * COLS + 1)
for r in range(ROWS):
for c in range(COLS):
if board[r][c] != "O":
continue
if (r == 0 or c == 0 or
r == (ROWS - 1) or c == (COLS - 1)
):
dsu.union(ROWS * COLS, r * COLS + c)
else:
for dx, dy in directions:
nr, nc = r + dx, c + dy
if board[nr][nc] == "O":
dsu.union(r * COLS + c, nr * COLS + nc)
for r in range(ROWS):
for c in range(COLS):
if not dsu.connected(ROWS * COLS, r * COLS + c):
board[r][c] = "X"Where is the number of rows and is the number of columns of the .