题目:

Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'.

A region is captured by flipping all 'O's into 'X's in that surrounded region.

For example,

X X X X
X O O X
X X O X
X O X X

After running your function, the board should be:

X X X X
X X X X
X X X X
X O X X 题解:
这道题是说一个O周围都是X那么这个O就得变成X。那么就可以发现四周这一圈如果有O肯定不能四周都被X包围,同时这个O也将会是潜在的内部的O的缺口,
让内部的O不能都被X覆盖。因此,思路就是先对四周的O进行特殊处理,用BFS走,把所有这个O连接的O(包括这个O)都涂成#。这样子,对于原来的棋盘来说,
没有变成#的O就是四周没有被O污染的,四周都是X,那么对其变成X。而所有#就是那些原来是O但是不是四周都被X包围的,把它们再还原成O。 代码如下:
 1 public void solve(char[][] board) {
 2     if(board==null || board.length<=1 || board[0].length<=1)
 3         return;
 4     
 5     //第一行和最后一行进行fill
 6     for(int i=0;i<board[0].length;i++){
 7         fill(board,0,i);
 8         fill(board,board.length-1,i);
 9     }
     
     //第一列和最后一列进行fill
     for(int i=0;i<board.length;i++){
         fill(board,i,0);
         fill(board,i,board[0].length-1);
     }
     
     //对于当前格子中,所有O变成X(说明符合要求,没有被变成#),所有#变成O
     for(int i=0;i<board.length;i++){
         for(int j=0;j<board[0].length;j++){
             if(board[i][j]=='O')
                 board[i][j]='X';
             else if(board[i][j]=='#')
                 board[i][j]='O';                
         }
     }
 }
 
 private void fill(char[][] board, int i, int j){
     if(board[i][j]!='O')
         return;
     board[i][j] = '#';
     //利用BFS
     LinkedList<Integer> queue = new LinkedList<Integer>();
     //先将矩阵的横纵坐标编码
     int code = i*board[0].length+j;
     queue.add(code);
     while(!queue.isEmpty()){
         code = queue.poll();
         int row = code/board[0].length;//从code中还原横坐标
         int col = code%board[0].length;//从code中还原纵坐标
         
         if(row>=1 && board[row-1][col]=='O'){//当前元素上边是否为0
             queue.add((row-1)*board[0].length + col);
             board[row-1][col]='#';
         }
         
         if(row<=board.length-2 && board[row+1][col]=='O'){//当前元素下面是否为0
             queue.add((row+1)*board[0].length + col);
             board[row+1][col]='#';
         }
         
         if(col>=1 && board[row][col-1]=='O'){//当前元素左边是否为0
             queue.add(row*board[0].length + col-1);
             board[row][col-1]='#';
         }
         
         if(col<=board[0].length-2 && board[row][col+1]=='O'){//当前元素右边是否为0
             queue.add(row*board[0].length + col+1);
             board[row][col+1]='#';
         }            
     }
 }
 Reference:http://blog.csdn.net/linhuanmars/article/details/22904855

Surrounded Regions leetcode java的更多相关文章

  1. Surrounded Regions——LeetCode

    Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A region is captured ...

  2. Surrounded Regions - LeetCode

    目录 题目链接 注意点 解法 小结 题目链接 https://leetcode.com/problems/surrounded-regions/ 注意点 边缘不算包围'O' 解法 解法一:dfs.找处 ...

  3. [LeetCode] Surrounded Regions 包围区域

    Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A region is captured ...

  4. 验证LeetCode Surrounded Regions 包围区域的DFS方法

    在LeetCode中的Surrounded Regions 包围区域这道题中,我们发现用DFS方法中的最后一个条件必须是j > 1,如下面的红色字体所示,如果写成j > 0的话无法通过OJ ...

  5. 【LeetCode】130. Surrounded Regions (2 solutions)

    Surrounded Regions Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A ...

  6. LeetCode: Surrounded Regions 解题报告

    Surrounded Regions Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A ...

  7. Leetcode之深度优先搜索(DFS)专题-130. 被围绕的区域(Surrounded Regions)

    Leetcode之深度优先搜索(DFS)专题-130. 被围绕的区域(Surrounded Regions) 深度优先搜索的解题详细介绍,点击 给定一个二维的矩阵,包含 'X' 和 'O'(字母 O) ...

  8. [LeetCode] 130. Surrounded Regions 包围区域

    Given a 2D board containing 'X' and 'O'(the letter O), capture all regions surrounded by 'X'. A regi ...

  9. 【leetcode】Surrounded Regions

    Surrounded Regions Given a 2D board containing 'X' and 'O', capture all regions surrounded by 'X'. A ...

随机推荐

  1. Adobe Photoshop CC 2017-18.0安装教程

    Adobe Photoshop CC 2017-18.0安装教程 注:下载链接在文章后面 第一步:首先请将电脑的网络断开,很简单:禁用本地连接或者拔掉网线,这样就可以免除登录Creative Clou ...

  2. CSUOJ 1162 Balls in the Boxes 快速幂

    Description Mr. Mindless has many balls and many boxes,he wants to put all the balls into some of th ...

  3. 解问 lambda表达式

    目录 1.0 何为Lambda 1.1 Lambda语法特征 1.2 Lambda实例 1.3 Lambda中的stream 1.4 Lambda 中的 stream 效率 1.0 何为Lambda ...

  4. CodeForces528A (STLset)

    题面 CodeForces 题解 横着切和竖着切是互相不影响的. 假设现在横着切成了很多段,显然此时面积最大的矩形的一边长就是这些段中长度最长的一段.竖着切的也是一样的. 所以就可以用\(set\)来 ...

  5. NPE是什么

    在编程中出现的空指针异常 Map类集合K/V能不能存储null值的情况,如下表格: remove元素要使用Iterator方式,如果并发操作,需要对Iterator对象加锁. Arrays.asLis ...

  6. 解决Ubuntu 16.04下提示boot分区空间不足的办法

    原文地址: http://www.jb51.net/article/106976.htm https://www.linuxidc.com/Linux/2015-09/123227.htm 因为lin ...

  7. 【BZOJ 2688】 2688: Green Hackenbush (概率DP+博弈-树上删边)

    2688: Green Hackenbush Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 42  Solved: 16 Description   ...

  8. ThinkPHP3.2设置异常页面404跳转页面

    在ThinkPHP3.2版本中当我们访问不存在的页面时会出现非常不友好错误提示页面,类如下图: 0 «上一篇:div非弹出框半透明遮罩实现全屏幕遮盖css实现»下一篇:利于反向代理绑定任意的域名 po ...

  9. hdu 3338 最大流 ****

    题意: 黑格子右上代表该行的和,左下代表该列下的和 链接:点我 这题可以用网络流做.以空白格为节点,假设流是从左流入,从上流出的,流入的容量为行和,流出来容量为列和,其余容量不变.求满足的最大流.由于 ...

  10. bzoj 2844 子集异或和名次

    感谢: http://blog.sina.cn/dpool/blog/s/blog_76f6777d0101d0mr.html 的讲解(特别是2^(n-m)的说明). /*************** ...