图论part2|200. 岛屿数量、695. 岛屿的最大面积

200、岛屿数量

  • 🔗:200. 岛屿数量 - 力扣(LeetCode)

  • 思路:

      1. 深度优先算法
      • 二叉树中dfs要素:1、访问左右相邻子节点 2、判断base case(终止条件)
      • 参考二叉树中的dfs看网格问题
        1. 网格的相邻节点:上下左右4个
      • 2.终止条件:超出格子的范围(--对应二叉树中全部为null的base case)
        1. 关键!!避免重复遍历,做过的格子需要进行标记
      1. 广度优先算法
      • 扫描整个二维网格,遇到为1的格子,加入队列当中,进行广度搜索
  • 代码

    • 深度优先算法
    java 复制代码
    class Solution {
    
        public int numIslands(char[][] grid) {
            int area = 0;
            for(int i=0; i<grid.length; i++){
                for(int j=0; j<grid[0].length; j++){
                    if(grid[i][j] == '1'){
                        area++;
                        dfs(grid, i, j);
                    }
                }
            }
            return area;
        }
    
        private void dfs(char[][] grid, int r, int c){
            if(!isArea(grid,r,c)){
                return;
            }
            if(grid[r][c] != '1'){
                return;
            }
            grid[r][c] = '2';
    
            dfs(grid, r-1, c);
            dfs(grid, r, c-1);
            dfs(grid, r+1, c);
            dfs(grid, r, c+1);
        }
    
        boolean isArea(char[][] grid, int r, int c){
            return 0<=r && r < grid.length 
                    && 0 <= c && c < grid[0].length;
        }
    }
    • 广度优先算法
      *

      java 复制代码
      class Solution {
          /**
          广度优先搜索bfs
          扫描整个二维网络,如果一个位置为1,加入队列,进行广度优先搜索
           */
          public int numIslands(char[][] grid) {
              if(grid == null || grid.length == 0){
                  return 0;
              }
      
              int nr = grid.length;
              int nc = grid[0].length;
              int nums_islands = 0;
      
              for(int r=0; r < nr; ++r){
                  for(int c = 0; c<nc; ++c){
                      if(grid[r][c] == '1'){
                          ++nums_islands;
                          grid[r][c] = '2';
                          Queue<Integer> neighbors = new LinkedList<>();
                          neighbors.add(r * nc + c);
                          while(!neighbors.isEmpty()){
                              int id = neighbors.remove();
                              int row = id / nc;
                              int col = id % nc;
                              if (row - 1 >= 0 && grid[row-1][col] == '1') {
                                  grid[row-1][col] = '2';
                                  neighbors.add((row-1) * nc + col);
                              }
                              if (row + 1 < nr && grid[row+1][col] == '1') {
                                  grid[row+1][col] = '2';
                                  neighbors.add((row+1) * nc + col);
                              }
                              if (col - 1 >= 0 && grid[row][col-1] == '1') {
                                  neighbors.add(row * nc + col-1);
                                  grid[row][col-1] = '2';
                              }
                              if (col + 1 < nc && grid[row][col+1] == '1') {
                                  neighbors.add(row * nc + col+1);
                                  grid[row][col+1] = '2';
                              }                      
                          }
                      }
                  }
              }
              return nums_islands;
          }

695. 岛屿的最大面积

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

  • 思路:深度优先搜索

  • 代码:

    java 复制代码
    class Solution {
        public int maxAreaOfIsland(int[][] grid) {
            if(grid.length==0||grid[0].length==0){
                return 0;
            }
    
            int res = 0;
            for(int r=0; r<grid.length; r++){
                for(int c=0; c<grid[0].length; c++){
                    if(grid[r][c]==1){
                        int a = area(grid, r, c);
                        res = Math.max(res,a);
                    }
                }
            }
            return res;
        }
    
        int area(int[][] grid, int r, int c){
            if (!(0 <= r && r < grid.length 
                && 0 <= c && c < grid[0].length)) {
                return 0;
            }
            if(grid[r][c] != 1){
                return 0;
            }
    
            grid[r][c] = 2;
            return 1 
                + area(grid, r-1, c)
                + area(grid, r+1, c)
                + area(grid, r, c-1)
                + area(grid, r, c+1);
        }
    }
相关推荐
Miraitowa_cheems19 分钟前
LeetCode算法日记 - Day 11: 寻找峰值、山脉数组的峰顶索引
java·算法·leetcode
CoovallyAIHub41 分钟前
方案 | 动车底部零部件检测实时流水线检测算法改进
深度学习·算法·计算机视觉
CoovallyAIHub43 分钟前
方案 | 光伏清洁机器人系统详细技术实施方案
深度学习·算法·计算机视觉
lxmyzzs1 小时前
【图像算法 - 14】精准识别路面墙体裂缝:基于YOLO12与OpenCV的实例分割智能检测实战(附完整代码)
人工智能·opencv·算法·计算机视觉·裂缝检测·yolo12
洋曼巴-young1 小时前
240. 搜索二维矩阵 II
数据结构·算法·矩阵
楼田莉子2 小时前
C++算法题目分享:二叉搜索树相关的习题
数据结构·c++·学习·算法·leetcode·面试
pusue_the_sun3 小时前
数据结构——栈和队列oj练习
c语言·数据结构·算法··队列
大锦终3 小时前
【算法】模拟专题
c++·算法
Xの哲學3 小时前
Perf使用详解
linux·网络·网络协议·算法·架构
想不明白的过度思考者4 小时前
数据结构(排序篇)——七大排序算法奇幻之旅:从扑克牌到百亿数据的魔法整理术
数据结构·算法·排序算法