跳到主要内容

Surrounded Regions

描述

Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'.

A region is captured by flipping all 'O's into 'X's in that surrounded region .

For example,

X X X X
X O O X
X X O X
X O X X

After running your function, the board should be:

X X X X
X X X X
X X X X
X O X X

分析

广搜。从上下左右四个边界往里走,凡是能碰到的'O',都是跟边界接壤的,应该保留。

代码

# Surrounded Regions
# BFS,时间复杂度O(n),空间复杂度O(n)
class Solution:
def solve(self, board):
if not board:
return

m = len(board)
n = len(board[0])
for i in range(n):
self.bfs(board, 0, i)
self.bfs(board, m - 1, i)
for j in range(1, m - 1):
self.bfs(board, j, 0)
self.bfs(board, j, n - 1)
for i in range(m):
for j in range(n):
if board[i][j] == 'O':
board[i][j] = 'X'
elif board[i][j] == '+':
board[i][j] = 'O'

def bfs(self, board, i, j):
from collections import deque
q = deque()
m = len(board)
n = len(board[0])

def state_is_valid(state):
x, y = state
if x < 0 or x >= m or y < 0 or y >= n or board[x][y] != 'O':
return False
return True

def state_extend(state):
result = []
x, y = state
# 上下左右
new_states = [(x-1, y), (x+1, y), (x, y-1), (x, y+1)]
for new_state in new_states:
if state_is_valid(new_state):
result.append(new_state)
return result

start = (i, j)
if state_is_valid(start):
board[i][j] = '+'
q.append(start)

while q:
cur = q.popleft()
new_states = state_extend(cur)
for s in new_states:
# 既有标记功能又有去重功能
board[s[0]][s[1]] = '+'
q.append(s)