• Day53:图论 岛屿数量 岛屿的最大面积


    99. 岛屿数量

    时间限制:1.000S  空间限制:256MB

    题目描述

    给定一个由 1(陆地)和 0(水)组成的矩阵,你需要计算岛屿的数量。岛屿由水平方向或垂直方向上相邻的陆地连接而成,并且四周都是水域。你可以假设矩阵外均被水包围。

    输入描述

    第一行包含两个整数 N, M,表示矩阵的行数和列数。

    后续 N 行,每行包含 M 个数字,数字为 1 或者 0。

    输出描述

    输出一个整数,表示岛屿的数量。如果不存在岛屿,则输出 0。

    输入示例
    1. 4 5
    2. 1 1 0 0 0
    3. 1 1 0 0 0
    4. 0 0 1 0 0
    5. 0 0 0 1 1
    输出示例
    3
    提示信息

    根据测试案例中所展示,岛屿数量共有 3 个,所以输出 3。

    数据范围:

    1 <= N, M <= 50

    思路:

    注意题目中每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。

    也就是说斜角度链接是不算了

    本题思路,是用遇到一个没有遍历过的节点陆地,计数器就加一,然后把该节点陆地所能遍历到的陆地都标记上。

    在遇到标记过的陆地节点和海洋节点的时候直接跳过。 这样计数器就是最终岛屿的数量。

    dfs:

    1. import java.util.*;
    2. class Main{
    3. public static void main(String[] args){
    4. int n,m;
    5. Scanner scanner = new Scanner(System.in);
    6. n=scanner.nextInt();
    7. m=scanner.nextInt();
    8. int[][] map=new int[n][m];
    9. for(int i=0;i<n;i++){
    10. for(int j=0;j<m;j++){
    11. map[i][j]=scanner.nextInt();
    12. }
    13. }
    14. int result=0;
    15. boolean[][] visited=new boolean[n][m];
    16. for(int i=0;i<n;i++){
    17. for( int j=0;j<m;j++){
    18. if((!visited[i][j])&&map[i][j]==1){
    19. result++;
    20. visited[i][j]=true;
    21. dfs(visited,map,i,j);
    22. }
    23. }
    24. }
    25. System.out.println(result);
    26. }
    27. public static void dfs(boolean[][] visited,int[][] map,int x,int y){
    28. int[][] dir={{0,1},{1,0},{-1,0},{0,-1}};
    29. for(int i=0;i<4;i++){
    30. int newx=x+dir[i][0];
    31. int newy=y+dir[i][1];
    32. if(newx>=0&&newx<map.length&&newy>=0&&newy<map[x].length&&!visited[newx][newy]&&map[newx][newy]==1){
    33. visited[newx][newy]=true;
    34. dfs(visited,map,newx,newy);
    35. }
    36. }
    37. }
    38. }

    BFS:

    注意这里为了避免超时,加入队列就标记为访问过,避免结点的重复加入

    1. import java.util.*;
    2. class Main{
    3. public static void main(String[] args){
    4. int n,m;
    5. Scanner scanner = new Scanner(System.in);
    6. n=scanner.nextInt();
    7. m=scanner.nextInt();
    8. int[][] map=new int[n][m];
    9. for(int i=0;i<n;i++){
    10. for(int j=0;j<m;j++){
    11. map[i][j]=scanner.nextInt();
    12. }
    13. }
    14. int result=0;
    15. boolean[][] visited=new boolean[n][m];
    16. for(int i=0;i<n;i++){
    17. for( int j=0;j<m;j++){
    18. if((!visited[i][j])&&map[i][j]==1){
    19. result++;
    20. visited[i][j]=true;
    21. bfs(visited,map,i,j);
    22. }
    23. }
    24. }
    25. System.out.println(result);
    26. }
    27. public static void bfs(boolean[][] visited, int[][] map, int x, int y) {
    28. int[][] dir = {{0, 1}, {1, 0}, {-1, 0}, {0, -1}};
    29. Queue<int[]> queue = new LinkedList();
    30. queue.offer(new int[]{x, y});
    31. visited[x][y] = true;
    32. while (!queue.isEmpty()) {
    33. int[] poll = queue.poll();
    34. int curx = poll[0];
    35. int cury = poll[1];
    36. for (int i=0;i<4;i++){
    37. int newx=curx+dir[i][0];
    38. int newy=cury+dir[i][1];
    39. if(newx>=0&&newx<map.length&&newy>=0&&newy<map[x].length&&!visited[newx][newy]&&map[newx][newy]==1){
    40. queue.add(new int[]{newx,newy});
    41. visited[newx][newy]=true;
    42. }
    43. }
    44. }
    45. }
    46. }

    100. 岛屿的最大面积

    时间限制:1.000S  空间限制:256MB

    题目描述

    给定一个由 1(陆地)和 0(水)组成的矩阵,计算岛屿的最大面积。岛屿面积的计算方式为组成岛屿的陆地的总数。岛屿由水平方向或垂直方向上相邻的陆地连接而成,并且四周都是水域。你可以假设矩阵外均被水包围。

    输入描述

    第一行包含两个整数 N, M,表示矩阵的行数和列数。后续 N 行,每行包含 M 个数字,数字为 1 或者 0,表示岛屿的单元格。

    输出描述

    输出一个整数,表示岛屿的最大面积。如果不存在岛屿,则输出 0。

    输入示例
    1. 4 5
    2. 1 1 0 0 0
    3. 1 1 0 0 0
    4. 0 0 1 0 0
    5. 0 0 0 1 1
    输出示例
    4
    提示信息

    样例输入中,岛屿的最大面积为 4。

    数据范围:

    1 <= M, N <= 50。

    思路:本题与上题一样,就是多了求每个岛屿面积的步骤

    1. import java.util.*;
    2. class Main {
    3. public static void main(String[] args) {
    4. int n, m;
    5. Scanner scanner = new Scanner(System.in);
    6. n = scanner.nextInt();
    7. m = scanner.nextInt();
    8. int[][] map = new int[n][m];
    9. for (int i = 0; i < n; i++) {
    10. for (int j = 0; j < m; j++) {
    11. map[i][j] = scanner.nextInt();
    12. }
    13. }
    14. int result = 0;
    15. boolean[][] visited = new boolean[n][m];
    16. for (int i = 0; i < n; i++) {
    17. for (int j = 0; j < m; j++) {
    18. if ((!visited[i][j]) && map[i][j] == 1) {
    19. visited[i][j] = true;
    20. int s= dfs(visited, map, i, j);
    21. result=Math.max(result,s);
    22. }
    23. }
    24. }
    25. System.out.println(result);
    26. }
    27. public static int dfs(boolean[][] visited, int[][] map, int x, int y) {
    28. int[][] dir = {{0, 1}, {1, 0}, {-1, 0}, {0, -1}};
    29. int s=0;
    30. Queue<int[]> queue = new LinkedList();
    31. queue.offer(new int[]{x, y});
    32. s++;
    33. visited[x][y] = true;
    34. while (!queue.isEmpty()) {
    35. int[] poll = queue.poll();
    36. int curx = poll[0];
    37. int cury = poll[1];
    38. for (int i=0;i<4;i++){
    39. int newx=curx+dir[i][0];
    40. int newy=cury+dir[i][1];
    41. if(newx>=0&&newx<map.length&&newy>=0&&newy<map[x].length&&!visited[newx][newy]&&map[newx][newy]==1){
    42. queue.add(new int[]{newx,newy});
    43. s++;
    44. visited[newx][newy]=true;
    45. }
    46. }
    47. }
    48. return s;
    49. }
    50. }

  • 相关阅读:
    LabVIEW专栏五、网口
    深度学习入门(五十六)循环神经网络——循环神经网络RNN
    consul python sdk
    1688商品详情(商品主图、sku)
    【Leetcode刷题Python】337. 打家劫舍 III
    StableSwarmUI 安装教程(详细)
    【错误记录】exe4j 打包程序无法设置 jar 包依赖的问题 ( 将源码 和 依赖库打包到同一个 jar 包中 )
    Windows远程访问本地 jupyter notebook服务
    结合Elementplus源码讲解BEM的使用
    JS如何实现一个注册按钮10秒倒计时效果
  • 原文地址:https://blog.csdn.net/2301_76352996/article/details/140440115