Botón Li: 130. Área rodeada (algoritmo de profundidad primero)

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);
    }

    
}

 

Supongo que te gusta

Origin blog.csdn.net/SIHUAZERO/article/details/128077619
Recomendado
Clasificación