首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Leetcode|DFS|130. 被围绕的区域

Leetcode|DFS|130. 被围绕的区域

作者头像
SL_World
发布2021-09-22 11:20:36
发布2021-09-22 11:20:36
3750
举报
文章被收录于专栏:XX

1 DFS

  • 遍历棋盘边界,将边界对应的所有O进行dfs遍历成#
  • 遍历棋盘,将所有中间O遍历成X
  • 遍历棋盘,将所有中间#恢复成O
代码语言:javascript
复制
class Solution {
public:
    int n, m;
    void dfs(vector<vector<char>>& board, int x, int y) {
        if (x < 0 || y < 0 || x >= n || y >= m || board[x][y] != 'O') return;
        board[x][y] = '#';
        dfs(board, x + 1, y);
        dfs(board, x - 1, y);
        dfs(board, x, y + 1);
        dfs(board, x, y - 1);
    }

    void solve(vector<vector<char>>& board) {
        n = board.size();
        m = board[0].size();
        // 第1行和最后1行中的O进行dfs变成其他图标
        for (int i = 0; i < n; i++) {
            if (board[i][0] == 'O') dfs(board, i, 0);
            if (board[i][m - 1] == 'O')  dfs(board, i, m - 1);
        }
        // 第1列和最后1列中的O进行dfs变成其他图标
        for (int i = 0; i < m; i++) {
            if (board[0][i] == 'O') dfs(board, 0, i);
            if (board[n - 1][i] == 'O')  dfs(board, n - 1, i);
        }
        // 将所有O变成X(可优化i从1开始遍历)
        for (int i = 1; i < n - 1; i++)
            for (int j = 1; j < m - 1; j++) 
                if (board[i][j] == 'O') board[i][j] = 'X';
        // 将所有#恢复成O
        for (int i = 0; i < n; i++)
            for (int j = 0; j < m; j++) 
                if (board[i][j] == '#') board[i][j] = 'O'; 
    }
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/06/29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 DFS
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档