floodfill算法系列一>被围绕的区域

目录

整体思想:

代码设计:

代码呈现:

java 复制代码
class Solution {
    int m,n;
    int[] dx = {0,0,-1,1};
    int[] dy = {-1,1,0,0};

    public void solve(char[][] board) {
        m = board.length;
        n = board[0].length;

        //先扫描边界,把不满足题意的连通块变为'.'
        for(int i = 0; i < n; i++){
            if(board[0][i] == 'O') dfs(board,0,i);
            if(board[m-1][i] == 'O') dfs(board,m-1,i);
        }

        for(int j = 0; j < m; j++){
            if(board[j][0] == 'O') dfs(board,j,0);
            if(board[j][n-1] == 'O') dfs(board,j,n-1);
        }


        //最后把'.'改会'o',把'o'改为'X'
        for(int i = 0; i < m; i++)
            for(int j = 0; j < n; j++){
                if(board[i][j] == 'O')
                    board[i][j] = 'X';
                else if(board[i][j] == '.')  
                    board[i][j] = 'O';
            }
    }

    private void dfs(char[][] board, int i, int j){
        board[i][j] = '.';

        for(int k = 0; k < 4; k++){
            int x = dx[k] + i; int y = dy[k] + j;
            if(x >= 0 && x < m && y >= 0 && y < n && board[x][y] == 'O'){
                dfs(board,x,y);
            }
        }
    }
}
相关推荐
陈浩源同学24 分钟前
学习 TypeScript 栈和队列数据结构
前端·算法
夏末秋也凉1 小时前
力扣-回溯-491 非递减子序列
数据结构·算法·leetcode
penguin_bark1 小时前
三、动规_子数组系列
算法·leetcode
kyle~1 小时前
thread---基本使用和常见错误
开发语言·c++·算法
曲奇是块小饼干_2 小时前
leetcode刷题记录(一百零八)——322. 零钱兑换
java·算法·leetcode·职场和发展
小wanga2 小时前
【leetcode】滑动窗口
算法·leetcode·职场和发展
少年芒2 小时前
Leetcode 490 迷宫
android·算法·leetcode
BingLin-Liu2 小时前
蓝桥杯备考:搜索算法之枚举子集
算法·蓝桥杯·深度优先
码农诗人2 小时前
调用openssl实现加解密算法
算法·openssl·ecdh算法
IT猿手3 小时前
2025最新智能优化算法:鲸鱼迁徙算法(Whale Migration Algorithm,WMA)求解23个经典函数测试集,MATLAB
android·数据库·人工智能·算法·机器学习·matlab·无人机