Obtenga un tablero de matriz mxn que consta de varios caracteres 'X' y 'O', busque todas las áreas rodeadas por 'X' y complete todas las 'O' en estas áreas con 'X'.
Ejemplo 1:
Nota: tablero = [["X","X","X","X"],["X","O","O","X"],["X","X", "O","X"],["X","O","X","X"]]
输出:[["X","X","X","X"],[" X","X","X","X"],["X","X","X","X"],["X","O","X","X" ]]
Explicación: El intervalo encerrado no existirá en el límite; en otras palabras, cualquier 'O' en el límite no se completará con 'X'. Cualquier 'O' que no esté en el límite, o que no esté conectada a una 'O' en el límite, terminará llenándose con una 'X'. Se dice que dos elementos están "conectados" si son adyacentes horizontal o verticalmente.
Ejemplo 2:
Entrada: placa = [["X"]]
Salida: [["X"]]
pista:
m == tablero.longitud
n == tablero[i].longitud
1 <= m, n <= 200
tablero[i][j] 为 'X' 或 'O'
Fuente: LeetCode
Enlace: https://leetcode.cn/problems/surrounded-regions
Los derechos de autor pertenecen a LeetCode Network. Para reimpresiones comerciales, comuníquese con la autorización oficial, para reimpresiones no comerciales, indique la fuente.
class Solution {
int n;
int m;
public void solve(char[][] board) {
n = board.length;
m = board[0].length;
//将边界的元素调用dfs方法.
for (int i = 0; i <= n - 1; i++) {
dfs(board, i, 0);
dfs(board, i, m - 1);
}
for (int i = 1; i <= m - 2; i++) {
dfs(board, 0, i);
dfs(board, n - 1, i);
}
//遍历二维数组,若被标记为A则为边界还原为O,否则改变为X.
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
if (board[i][j] == 'A') {
board[i][j] = 'O';
} else if (board[i][j] == 'O') {
board[i][j] = 'X';
}
}
}
}
//标记边界及其连接的'O';
public void dfs(char[][] board, int x, int y) {
//递归边界,如果超过边界或者不为'O'.
if (x < 0 || x > n - 1 || y < 0 || y > m - 1 || board[x][y] != 'O') {
return;
}
board[x][y] = 'A';
dfs(board, x + 1, y);
dfs(board, x - 1, y);
dfs(board, x, y + 1);
dfs(board, x, y - 1);
}
}