[算法基础] FooldFill(DFS、BFS)

695. 岛屿的最大面积 - 力扣(LeetCode)

DFS 完整代码:

java 复制代码
class Solution {
    int[][] grid;
    int rows;
    int columns;
    int area;

    public int maxAreaOfIsland(int[][] grid) {
        this.grid = grid;
        rows = grid.length;
        columns = grid[0].length;

        int maxArea = 0;

        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < columns; j++) {
                if (grid[i][j] == 1) {
                    dfs(i, j);
                    maxArea = Math.max(maxArea, area);
                    area = 0;
                }
            }
        }

        return maxArea;
    }

    private void dfs(int r, int c) {
        if (r < 0 || r >= rows || c < 0 || c >= columns
                || grid[r][c] != 1) {
            return;
        }

        grid[r][c] = 2;
        area++;

        dfs(r - 1, c);
        dfs(r + 1, c);
        dfs(r, c - 1);
        dfs(r, c + 1);
    }
}

BFS 完整代码:

java 复制代码
class Solution {
    int[][] grid;
    int rows;
    int columns;

    static class Pair {
        int row;
        int column;

        public Pair(int row, int column) {
            this.row = row;
            this.column = column;
        }
    }

    public int maxAreaOfIsland(int[][] grid) {
        this.grid = grid;
        rows = grid.length;
        columns = grid[0].length;

        int ret = 0;

        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < columns; j++) {
                if (grid[i][j] == 1) {
                    int area = bfs(new Pair(i, j));
                    ret = Math.max(ret, area);
                }
            }
        }

        return ret;
    }

    public int bfs(Pair pair) {
        int ret = 0;
        Queue<Pair> queue = new LinkedList<>();
        queue.add(pair);

        while (!queue.isEmpty()) {
            Pair temp = queue.poll();
            int r = temp.row;
            int c = temp.column;

            if (r < 0 || r >= rows || c < 0 || c >= columns
                    || grid[r][c] != 1) {
                continue;
            }

            grid[r][c] = 2;
            ret++;

            queue.add(new Pair(r - 1, c));
            queue.add(new Pair(r + 1, c));
            queue.add(new Pair(r, c - 1));
            queue.add(new Pair(r, c + 1));
        }

        return ret;
    }
}

130. 被围绕的区域 - 力扣(LeetCode)

正难则反。这道题要找所有被围绕的 O 区域,不太好找,因此我们可以先找那些不被围绕的 O 区域,这些区域是好找的,因为它们一定至少有一个坐标是位于矩阵边缘的。现在我们仅需探测矩阵的边缘即可,碰到 O 就 DFS 进去。

java 复制代码
class Solution {
    char[][] board;
    int rows;
    int columns;
    boolean[][] notSurrounded; // 记录所有不被围绕的区域为 true

    public void solve(char[][] board) {
        this.board = board;
        rows = board.length;
        columns = board[0].length;
        this.notSurrounded = new boolean[rows][columns];

        // 找上边缘和下边缘
        for (int i = 0; i < rows; i++) {
            if (board[i][0] == 'O') {
                dfs(i, 0);
            }
            if (board[i][columns - 1] == 'O') {
                dfs(i, columns - 1);
            }
        }

        // 找左边缘和右边缘
        for (int j = 1; j < columns - 1; j++) {
            if (board[0][j] == 'O') {
                dfs(0, j);
            }
            if (board[rows - 1][j] == 'O') {
                dfs(rows - 1, j);
            }
        }

        // 再次遍历,找被围绕区域
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < columns; j++) {
                if (board[i][j] == 'O' && !notSurrounded[i][j]) {
                    board[i][j] = 'X';
                }
            }
        }
    }

    private void dfs(int r, int c) {
        // 坐标越界 || 不是 O || 该坐标已经走过
        if (r < 0 || r >= rows || c < 0 || c >= columns
                || board[r][c] != 'O' || notSurrounded[r][c]) {
            return;
        }

        notSurrounded[r][c] = true;

        dfs(r - 1, c);
        dfs(r + 1, c);
        dfs(r, c - 1);
        dfs(r, c + 1);
    }
}
相关推荐
Jay Kay3 小时前
GVPO:Group Variance Policy Optimization
人工智能·算法·机器学习
Epiphany.5563 小时前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
YuTaoShao3 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
茉莉玫瑰花茶3 小时前
C++ 17 详细特性解析(5)
开发语言·c++·算法
cpp_25014 小时前
P10570 [JRKSJ R8] 网球
数据结构·c++·算法·题解
cpp_25014 小时前
P8377 [PFOI Round1] 暴龙的火锅
数据结构·c++·算法·题解·洛谷
uesowys4 小时前
Apache Spark算法开发指导-Factorization machines classifier
人工智能·算法
季明洵4 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
shandianchengzi4 小时前
【小白向】错位排列|图文解释公考常见题目错位排列的递推式Dn=(n-1)(Dn-2+Dn-1)推导方式
笔记·算法·公考·递推·排列·考公
I_LPL4 小时前
day26 代码随想录算法训练营 回溯专题5
算法·回溯·hot100·求职面试·n皇后·解数独