给你一个 m ∗ n m * n m∗n 的矩阵 board ,由若干字符 ‘X’ 和 ‘O’ ,找到所有被 ‘X’ 围绕的区域,并将这些区域里所有的 ‘O’ 用 ‘X’ 填充。
输入:board = [[“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”]]
解释:被围绕的区间不会存在于边界上,换句话说,任何边界上的 ‘O’ 都不会被填充为 ‘X’。 任何不在边界上,或不与边界上的 ‘O’ 相连的 ‘O’ 最终都会被填充为 ‘X’。如果两个元素在水平或垂直方向相邻,则称它们是“相连”的。
输入:board = [[“X”]]
输出:[[“X”]]
m == board.length
n == board[i].length
1 <= m, n <= 200
board[i][j] 为 ‘X’ 或 ‘O’
public class dfs_surronded {
public static void main(String[] args) {
// TODO 自动生成的方法存根
char [][] board = {
{'X', 'X', 'X', 'X'},
{'X', 'O', 'X', 'X'},
{'X', 'X', 'O', 'O'},
{'O', 'X', 'X', 'X'}
};
solve(board);
}
private static int m, n;
private static int [][] dircetion = {{1,0},{0,1},{-1,0},{0,-1}};
public static void solve(char[][] board) {
if(board == null || board.length == 0) {
return;
}
m = board.length;
n = board[0].length;
for(int i = 0; i < m; i++) {
if(board[i][0] == 'O') {
dfs(i, 0, board);
}
if(board[i][n-1] == 'O') {
dfs(i, n-1, board);
}
}
for(int j = 1; j < n - 1; j++) {
if(board[0][j] == 'O') {
dfs(0, j, board);
}
if(board[m-1][j] == 'O') {
dfs(m-1, j, board);
}
}
for(int i = 0; i < m; i++) {
for(int j = 0; j < n; j++) {
if(board[i][j] == 'O') {
board[i][j] = 'X';
}
}
}
for(int i = 0; i < m; i++) {
for(int j = 0; j < n; j++) {
if(board[i][j] == '-') {
board[i][j] = 'O';
}
System.out.print(board[i][j] + " ");
}
System.out.println();
}
return;
}
private static void dfs(int r, int c, char[][] board) {
// TODO 自动生成的方法存根
if(r < 0 || r >= m || c < 0 || c >= n || board[r][c] != 'O')
return;
board[r][c] = '-';
for(int dir[] : dircetion) {
dfs(r+dir[0], c+dir[1], board);
}
return;
}
}
来源:力扣