博客
关于我
leetcode------130. 被围绕的区域【1】
阅读量:203 次
发布时间:2019-02-28

本文共 1382 字,大约阅读时间需要 4 分钟。

为了解决这个问题,我们需要找到所有被 'X' 围绕的区域,并将这些区域内的 'O' 填充为 'X'。边界上的 'O' 不会被填充,因为它们无法被 'X' 围绕。

方法思路

我们可以使用广度优先搜索(BFS)来解决这个问题。具体步骤如下:

  • 标记边界的 'O':首先,我们标记所有位于矩阵边界的 'O',这些 'O' 不会被填充,因为它们无法被 'X' 围绕。
  • BFS 遍历:然后,我们从这些边界的 'O' 开始,使用 BFS 遍历所有与这些边界 'O' 相连的 'O'。这些 'O' 也不会被填充,因为它们可以逃脱到边界。
  • 填充内部 'O':剩下的未被访问过的内部 'O' 会被填充为 'X',因为它们无法逃脱到边界。
  • 解决代码

    #include 
    #include
    using namespace std;void solve(vector
    > &board) { int n = board.size(); if (n == 0) return; int m = board[0].size(); vector
    > visited(n, vector
    (m, false)); queue
    > q; // 初始化边界的'O' for (int i = 0; i < n; ++i) { for (int j = 0; j < m; ++j) { if (i == 0 || i == n-1 || j == 0 || j == m-1) { if (board[i][j] == 'O') { visited[i][j] = true; q.push({i, j}); } } } } // 四个方向:上下左右 int dirs[4][2] = {{-1,0}, {1,0}, {0,-1}, {0,1}}; while (!q.empty()) { auto current = q.front(); q.pop(); int x = current.first; int y = current.second; for (int d = 0; d < 4; ++d) { int nx = x + dirs[d][0]; int ny = y + dirs[d][1]; if (nx >= 0 && nx < n && ny >=0 && ny < m) { if (board[nx][ny] == 'O' && !visited[nx][ny]) { visited[nx][ny] = true; q.push({nx, ny}); } } } } // 填充内部未被访问的'O' for (int i=0; i

    代码解释

  • 初始化边界 'O':我们遍历矩阵的边界,标记所有 'O' 并将它们加入队列。
  • BFS 遍历:从队列中取出元素,检查其四个邻居。如果邻居是 'O' 且未被访问过,则标记并加入队列。
  • 填充内部 'O':遍历整个矩阵,未被访问过的内部 'O' 被填充为 'X'。
  • 这种方法确保了所有无法逃脱到边界的 'O' 被正确填充为 'X',同时边界上的 'O' 保持不变。

    转载地址:http://tnki.baihongyu.com/

    你可能感兴趣的文章
    PGSQL主键序列
    查看>>
    PGSQL安装PostGIS扩展模块
    查看>>
    pg数据库中两个字段相除
    查看>>
    PhalApi:[1.23] 请求和响应:GET和POST两者皆可得及超越JSON格式返回
    查看>>
    Phalcon环境搭建与项目开发
    查看>>
    Phantom.js维护者退出,项目的未来成疑
    查看>>
    Pharmaceutical的同学们都看过来,关于补码运算的复习相关内容
    查看>>
    Phoenix 查看表信息及修改元数据
    查看>>
    Phoenix基础命令_视图映射和表映射_数字存储问题---大数据之Hbase工作笔记0036
    查看>>
    phoenix无法连接hbase shell创建表失败_报错_PleaseHoldException: Master is initializing---记录020_大数据工作笔记0180
    查看>>
    Phoenix简介_安装部署_以及连接使用---大数据之Hbase工作笔记0035
    查看>>
    phoenix连接hbase报错Can not resolve hadoop120, please check your network_记录026---大数据工作笔记0187
    查看>>
    Photoshop工作笔记001---Photoshop常用快捷键总结
    查看>>
    Reids配置文件redis.conf中文详解
    查看>>
    Photoshop脚本入门
    查看>>
    PHP
    查看>>
    Regular Expression Notes
    查看>>
    PHP $FILES error码对应错误信息
    查看>>
    PHP $_FILES函数详解
    查看>>
    PHP $_SERVER['HTTP_REFERER'] 获取前一页面的 URL 地址
    查看>>