100道面试必会算法-18-岛屿问题(数量、周长、面积)

100道面试必会算法-18-岛屿问题(数量、周长、面积)

题目描述

给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量。

岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。

此外,你可以假设该网格的四条边均被水包围。

示例 1:

输入:grid = [
  ["1","1","1","1","0"],
  ["1","1","0","1","0"],
  ["1","1","0","0","0"],
  ["0","0","0","0","0"]
]
输出:1

示例 2:

输入:grid = [
  ["1","1","0","0","0"],
  ["1","1","0","0","0"],
  ["0","0","1","0","0"],
  ["0","0","0","1","1"]
]
输出:3

解题思路

采用深度优先遍历思想,传送门:https://leetcode.cn/problems/number-of-islands/solutions/211211/dao-yu-lei-wen-ti-de-tong-yong-jie-fa-dfs-bian-li-/

值得注意一个问题

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

以上写法问题,if内判断是需要注意顺序的,倘若发生越界要注意判断条件,grid[i][j]!= '1'的判断需要在i<0,j<0后,若先进行判断则可能会发生越界错误

代码

public class LC13 {
    public int numIslands(char[][] grid) {
        int count=0;
        for (int i = 0; i < grid.length; i++) {
            for (int j = 0; j < grid[0].length; j++) {
                if (grid[i][j]=='1'){
                    dfs(grid,i,j);
                    count++;
                }
            }
        }
        return count;
    }

    private void dfs(char[][] grid, int i, int j) {
//        第一种写法(不通过)
//        if (i >= grid.length || j >= grid[0].length || grid[i][j] != '1' || i<0|| j<0)return;

//        第二种写法(通过)
          if (i<0 || j<0 || i >= grid.length || j >= grid[0].length || grid[i][j] != '1' )return;

//        第三种写法(通过)
//        if (i >= grid.length || j >= grid[0].length || i < 0 || j < 0) {
//            return;
//        }
//        if (grid[i][j] != '1') {
//            return;
//        }
        grid[i][j]='2';
        dfs(grid, i-1, j);
        dfs(grid, i+1, j);
        dfs(grid, i, j-1);
        dfs(grid, i, j+1);
    }
    public static void main(String[] args) {
        // 创建一个示例对象
        LC13 main = new LC13();
        // 测试用例
        char[][] grid = {
                {'1', '1', '0', '0', '0'},
                {'1', '1', '0', '0', '0'},
                {'0', '0', '1', '0', '0'},
                {'0', '0', '0', '1', '1'}
        };
        // 调用numIslands方法计算岛屿数量
        int islands = main.numIslands(grid);
        // 输出结果
        System.out.println("岛屿数量为:" + islands);
    }
}

面积

int area(int[][] grid, int r, int c) {  
    return 1 
        + area(grid, r - 1, c)
        + area(grid, r + 1, c)
        + area(grid, r, c - 1)
        + area(grid, r, c + 1);
}


周长

c)
+ area(grid, r + 1, c)
+ area(grid, r, c - 1)
+ area(grid, r, c + 1);
}


周长

相关推荐

  1. 100面试算法-07-用 Rand7() 实现 Rand10()

    2024-04-04 18:56:01       50 阅读
  2. Redis面试10

    2024-04-04 18:56:01       37 阅读
  3. 刷题Day54|99. 岛屿数量100. 岛屿的最大面积

    2024-04-04 18:56:01       30 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-04 18:56:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-04 18:56:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-04 18:56:01       87 阅读
  4. Python语言-面向对象

    2024-04-04 18:56:01       96 阅读

热门阅读

  1. Kali Linux介绍

    2024-04-04 18:56:01       33 阅读
  2. 4.3学习计划

    2024-04-04 18:56:01       38 阅读
  3. 34-1 SSRF漏洞 - SSRF服务端请求伪造

    2024-04-04 18:56:01       38 阅读
  4. Node.js 的常用命令

    2024-04-04 18:56:01       36 阅读
  5. 第十一届“图灵杯“NEUQ-ACM程序设计竞赛

    2024-04-04 18:56:01       37 阅读
  6. vue监听键盘回车事件的三种方法

    2024-04-04 18:56:01       37 阅读
  7. Spring Bean 的一生

    2024-04-04 18:56:01       34 阅读