代码随想录三刷day51

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • [一、力扣200. 岛屿数量](#一、力扣200. 岛屿数量)
  • [二、力扣695. 岛屿的最大面积](#二、力扣695. 岛屿的最大面积)
  • [三、力扣1020. 飞地的数量](#三、力扣1020. 飞地的数量)
  • [四、力扣130. 被围绕的区域](#四、力扣130. 被围绕的区域)

前言


依然是从地图周边出发,将周边空格相邻的'O'都做上标记,然后在遍历一遍地图,遇到 'O' 且没做过标记的,那么都是地图中间的'O',全部改成'X'就行。

一、力扣200. 岛屿数量

java 复制代码
class Solution {
    int[][] arr = new int[][]{{0,1},{0,-1},{-1,0},{1,0}};
    boolean[][] flag;
    public int numIslands(char[][] grid) {
        int m = grid.length, n = grid[0].length;
        int res = 0;
        flag = new boolean[m][n];
        for(int i = 0; i < m; i ++){
            for(int j = 0; j < n; j ++){
                if(!flag[i][j] && grid[i][j] == '1'){
                    res ++;
                    bfs(grid, i, j);
                }
            }
        }
        return res;
    }
    public void bfs(char[][] grid, int x, int y){
        Deque<int[]> deq = new LinkedList<>();
        deq.offerLast(new int[]{x,y});
        while(!deq.isEmpty()){
            int size = deq.size();
            for(int i = 0; i < size; i ++){
                int[] cur = deq.pollFirst();
                for(int j = 0; j < 4; j ++){
                    int curX = cur[0] + arr[j][0];
                    int curY = cur[1] + arr[j][1];
                    if(curX < 0 || curX >= grid.length || curY < 0 || curY >= grid[0].length){
                        continue;
                    }
                    if(!flag[curX][curY] && grid[curX][curY] == '1'){
                        flag[curX][curY] = true;
                        deq.offerLast(new int[]{curX,curY});
                    }
                }
            }
        }
    }
}

二、力扣695. 岛屿的最大面积

java 复制代码
class Solution {
    int res = 0;
    int count = 0;
    int[][] arr = new int[][]{{0,1},{0,-1},{-1,0},{1,0}};
    boolean[][] flag;
    public int maxAreaOfIsland(int[][] grid) {
        int m = grid.length, n = grid[0].length;
        flag = new boolean[m][n];
        for(int i = 0; i < m; i ++){
            for(int j = 0; j < n; j ++){
                if(!flag[i][j] && grid[i][j] == 1){
                    flag[i][j] = true;
                    count = 1;
                    dfs(grid,i,j);
                }
            }
        }
        return res;
    }
    public void dfs(int[][] grid, int x, int y){
        res = Math.max(count,res);
        for(int i = 0; i < 4; i ++){
            int curX = x + arr[i][0];
            int curY = y + arr[i][1];
            if(curX < 0 || curX >= grid.length || curY < 0 || curY >= grid[0].length){
                continue;
            }
            if(!flag[curX][curY] && grid[curX][curY] == 1){
                flag[curX][curY] = true;
                count ++;
                dfs(grid,curX,curY);
            }
        }
    }
}

三、力扣1020. 飞地的数量

java 复制代码
class Solution {
    int res = 0;
    int count = 0;
    int[][] arr = new int[][]{{0,1},{0,-1},{-1,0},{1,0}};
    boolean[][] flag;
    boolean f;
    public int numEnclaves(int[][] grid) {
        int m = grid.length, n = grid[0].length;
        flag = new boolean[m][n];
        for(int i = 0; i < m; i ++){
            for(int j = 0; j < n; j ++){
                if(!flag[i][j] && grid[i][j] == 1){
                    flag[i][j] = true;
                    count = 1;
                    f = false;
                    dfs(grid,i,j);
                    if(!f){
                        res += count;
                    }
                }
            }
        }
        return res;
    }
    public void dfs(int[][] grid, int x, int y){
        for(int i = 0; i < 4; i ++){
            int curX = x + arr[i][0];
            int curY = y + arr[i][1];
            if(curX < 0 || curX >= grid.length || curY < 0 || curY >= grid[0].length){
                f = true;
                continue;
            }
            if(!flag[curX][curY] && grid[curX][curY] == 1){
                count ++;
                flag[curX][curY] = true;
                dfs(grid,curX,curY);
            }
        }
    }
}

四、力扣130. 被围绕的区域

java 复制代码
class Solution {
    int[][] arr = new int[][]{{0,1},{0,-1},{-1,0},{1,0}};
    boolean[][] flag;
    public void solve(char[][] board) {
        int m = board.length, n = board[0].length;
        flag = new boolean[m][n];
        for(int i = 0; i < m; i ++){
            if(!flag[i][0] && board[i][0] == 'O'){
                flag[i][0] = true;
                dfs(board, i, 0);
            }
            if(!flag[i][n-1] && board[i][n-1] == 'O'){
                flag[i][n-1] = true;
                dfs(board,i,n-1);
            }
        }
        for(int i = 0; i < n; i ++){
            if(!flag[0][i] && board[0][i] == 'O'){
                flag[0][i] = true;
                dfs(board,0,i);
            }
            if(!flag[m-1][i] && board[m-1][i] == 'O'){
                flag[m-1][i] = true;
                dfs(board,m-1,i);
            }
        }
        for(int i = 0; i < m; i ++){
            for(int j = 0; j < n; j ++){
                if(!flag[i][j] && board[i][j] == 'O'){
                    board[i][j] = 'X';
                }
            }
        }
    }
    public void dfs(char[][] board, int x, int y){
        for(int i = 0; i < 4; i++){
            int curX = x + arr[i][0];
            int curY = y + arr[i][1];
            if(curX < 0 || curX >= board.length || curY < 0 || curY >= board[0].length){
                continue;
            }
            if(!flag[curX][curY] && board[curX][curY] == 'O'){
                flag[curX][curY] = true;
                dfs(board,curX,curY);
            }
        }
    }
}
相关推荐
_殊途37 分钟前
《Java HashMap底层原理全解析(源码+性能+面试)》
java·数据结构·算法
珊瑚里的鱼4 小时前
LeetCode 692题解 | 前K个高频单词
开发语言·c++·算法·leetcode·职场和发展·学习方法
秋说5 小时前
【PTA数据结构 | C语言版】顺序队列的3个操作
c语言·数据结构·算法
lifallen5 小时前
Kafka 时间轮深度解析:如何O(1)处理定时任务
java·数据结构·分布式·后端·算法·kafka
liupenglove6 小时前
自动驾驶数据仓库:时间片合并算法。
大数据·数据仓库·算法·elasticsearch·自动驾驶
python_tty7 小时前
排序算法(二):插入排序
算法·排序算法
然我7 小时前
面试官:如何判断元素是否出现过?我:三种哈希方法任你选
前端·javascript·算法
F_D_Z7 小时前
【EM算法】三硬币模型
算法·机器学习·概率论·em算法·极大似然估计
秋说8 小时前
【PTA数据结构 | C语言版】字符串插入操作(不限长)
c语言·数据结构·算法
凌肖战9 小时前
力扣网编程135题:分发糖果(贪心算法)
算法·leetcode