力扣面试150题--被围绕的区域

Day 60

题目描述

思路

中译中 此题的目的在于找到被X包围的O,没有被完全包围(指与边缘的O相连)不算,将完全包围的O变成X
做法 :根据以上中译中,我们可以逆向思维,从边缘的O开始找到与其相连的O,这种岛屿是不需要修改为X,我们将其修改为1,在最后再统一处理,将1改为O,将O改为X。

具体找到i相连的岛屿,可以通过深度搜索实现。

java 复制代码
class Solution {
    public void dfs(char[][]board,int i,int j){
        if(i>=board.length||i<0||j<0||j>=board[0].length||board[i][j]!='O'){//超出边缘或者不为0就返回
            return;
        }
        //边缘为0
        board[i][j]='1';
        dfs(board,i-1,j);
        dfs(board,i+1,j);
        dfs(board,i,j-1);
        dfs(board,i,j+1);

    }
    public void solve(char[][] board) {
        //换个思路,只要和边缘的O相连的都是不该被改成X的点
        for(int j=0;j<board[0].length;j++){//第一行和最后一行
            dfs(board,0,j);
            dfs(board,board.length-1,j);
        }
        for(int i=0;i<board.length;i++){//第一列和最后一列
            dfs(board,i,0);
            dfs(board,i,board[0].length-1);
        }
        for(int i=0;i<board.length;i++){
            for(int j=0;j<board[0].length;j++){
                if(board[i][j]=='1'){
                    board[i][j]='O';
                }
                else if(board[i][j]=='O'){
                    board[i][j]='X';
                }
                else{
                    board[i][j]=board[i][j];
                }
            }
        }
        return;
    }
}
相关推荐
2351626 分钟前
【LeetCode】3. 无重复字符的最长子串
java·后端·算法·leetcode·职场和发展
零雲42 分钟前
java面试:可以讲一讲sychronized和ReentrantLock的异同点吗
java·开发语言·面试
crystal_pin1 小时前
前端流式解析chunk数据思路
面试
甜瓜看代码1 小时前
面试---h5秒开优化
面试
微笑尅乐1 小时前
神奇的位运算——力扣136.只出现一次的数字
java·算法·leetcode·职场和发展
自信的小螺丝钉2 小时前
Leetcode 155. 最小栈 辅助栈
leetcode·
吃着火锅x唱着歌2 小时前
LeetCode 3105.最长的严格递增或递减子数组
算法·leetcode·职场和发展
zcychong2 小时前
如何让A、B、C三个线程按严格顺序执行(附十一种解)?
java·面试
吃着火锅x唱着歌2 小时前
LeetCode 2765.最长交替子数组
算法·leetcode·职场和发展
墨染点香3 小时前
LeetCode 刷题【91. 解码方法】
算法·leetcode·职场和发展