day-35 被围绕的区域

思路

很明显,只有与边界上的O连接的O才不会X覆盖

解题方法

检测边界上的字符,如果是O则向周围探测,访问与之连接的不会被覆盖的X。边界探测结束后,没有访问过的O皆会被X覆盖

Code

java 复制代码
class Solution {
    public int dir[][]={{0,1},{0,-1},{1,0},{-1,0}};
    public boolean vis[][];
    public char[][] map;
    public int m;
    public int n;
    public void solve(char[][] board) {
        m=board.length;
        n=board[0].length;
        map=board;
        vis=new boolean[m][n];
        for(int i=0;i<m;i++){
            dfs(i,0);
            dfs(i,n-1);
        }
        for(int i=1;i<n-1;i++){
            dfs(0,i);
            dfs(m-1,i);
        }
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                board[i][j]='X';
            }
        }
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(map[i][j]=='X'&&vis[i][j]){
                    board[i][j]='O';
                }
            }
        }
    }
    void dfs(int x,int y){
        if(map[x][y]=='X') return;
        vis[x][y]=true;
        for(int i=0;i<4;i++){
            int newx=x+dir[i][0];
            int newy=y+dir[i][1];
            if(0<=newx&&newx<m&&0<=newy&&newy<n&&map[newx][newy]=='O'&&
            !vis[newx][newy]){
                dfs(newx,newy);
            }
        }
    }
}
相关推荐
blackicexs10 分钟前
第四周第四天
数据结构·c++·算法
TracyCoder12313 分钟前
LeetCode Hot100(46/100)——74. 搜索二维矩阵
算法·leetcode·矩阵
foundbug99916 分钟前
果蝇优化算法(FOA)详解:原理、实现与应用
算法
游乐码16 分钟前
c#递归函数
算法·c#
Pluchon16 分钟前
硅基计划4.0 算法 简单实现B树
java·数据结构·b树·算法·链表
im_AMBER26 分钟前
Leetcode 119 二叉树展开为链表 | 路径总和
数据结构·学习·算法·leetcode·二叉树
Eloudy29 分钟前
SuiteSparse 的 README
人工智能·算法·机器学习·hpc
苏荷水1 小时前
万字总结LeetCode100(持续更新...)
java·算法·leetcode·职场和发展
gihigo19981 小时前
MATLAB运动估计基本算法详解
开发语言·算法·matlab
hetao17338371 小时前
2026-02-09~02-12 hetao1733837 的刷题记录
c++·算法