Day53:图论 岛屿数量 岛屿的最大面积
创始人
2025-01-11 00:03:41
0

99. 岛屿数量

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

题目描述

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

输入描述

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

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

输出描述

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

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

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

数据范围:

1 <= N, M <= 50

思路:

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

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

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

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

dfs:

import java.util.*;  class Main{          public static void main(String[] args){         int n,m;         Scanner scanner = new Scanner(System.in);         n=scanner.nextInt();         m=scanner.nextInt();         int[][] map=new int[n][m];         for(int i=0;i{0,1},{1,0},{-1,0},{0,-1}};         for(int i=0;i<4;i++){             int newx=x+dir[i][0];             int newy=y+dir[i][1];             if(newx>=0&&newx=0&&newy

BFS:

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

import java.util.*;  class Main{          public static void main(String[] args){         int n,m;         Scanner scanner = new Scanner(System.in);         n=scanner.nextInt();         m=scanner.nextInt();         int[][] map=new int[n][m];         for(int i=0;i{0, 1}, {1, 0}, {-1, 0}, {0, -1}};         Queue queue = new LinkedList();         queue.offer(new int[]{x, y});         visited[x][y] = true;         while (!queue.isEmpty()) {             int[] poll = queue.poll();             int curx = poll[0];             int cury = poll[1];             for (int i=0;i<4;i++){                 int newx=curx+dir[i][0];                 int newy=cury+dir[i][1];                 if(newx>=0&&newx=0&&newy

100. 岛屿的最大面积

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

题目描述

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

输入描述

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

输出描述

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

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

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

数据范围:

1 <= M, N <= 50。

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

import java.util.*;  class Main {      public static void main(String[] args) {         int n, m;         Scanner scanner = new Scanner(System.in);         n = scanner.nextInt();         m = scanner.nextInt();         int[][] map = new int[n][m];         for (int i = 0; i < n; i++) {             for (int j = 0; j < m; j++) {                 map[i][j] = scanner.nextInt();             }         }         int result = 0;         boolean[][] visited = new boolean[n][m];          for (int i = 0; i < n; i++) {             for (int j = 0; j < m; j++) {                 if ((!visited[i][j]) && map[i][j] == 1) {                                      visited[i][j] = true;                   int s=  dfs(visited, map, i, j);                   result=Math.max(result,s);                                       }             }         }         System.out.println(result);     }      public static int dfs(boolean[][] visited, int[][] map, int x, int y) {         int[][] dir = {{0, 1}, {1, 0}, {-1, 0}, {0, -1}};         int s=0;         Queue queue = new LinkedList();         queue.offer(new int[]{x, y});         s++;         visited[x][y] = true;         while (!queue.isEmpty()) {             int[] poll = queue.poll();             int curx = poll[0];             int cury = poll[1];             for (int i=0;i<4;i++){                 int newx=curx+dir[i][0];                 int newy=cury+dir[i][1];                 if(newx>=0&&newx=0&&newy

相关内容

热门资讯

第5分钟了解!悠闲卡五星辅助,... 第5分钟了解!悠闲卡五星辅助,多多科技手游辅助,秘籍教程(有挂细节)-哔哩哔哩1、多多科技手游辅助免...
第九分钟了解!拱趴大菠萝辅助器... 第九分钟了解!拱趴大菠萝辅助器,悦悦娱乐辅助,讲义教程(有人有挂)-哔哩哔哩1、首先打开拱趴大菠萝辅...
4分钟了解!微信小程序哥哥跑得... 4分钟了解!微信小程序哥哥跑得快脚本下载,蛮王辅助器,方针教程(有挂规律)-哔哩哔哩1、下载好微信小...
五分钟了解!奇迹脚本辅助器免费... 五分钟了解!奇迹脚本辅助器免费,九九联盟破解版,步骤教程(有挂细节)-哔哩哔哩所有人都在同一条线上,...
第八分钟了解!决战十三辅助辅助... 第八分钟了解!决战十三辅助辅助器,河南微乐小程序辅助器免费,大纲教程(有挂教程)-哔哩哔哩1、任何河...
第二分钟了解!闲逸碰胡辅助软件... 第二分钟了解!闲逸碰胡辅助软件,微信微乐辅助,资料教程(有挂细节)-哔哩哔哩1、闲逸碰胡辅助软件辅助...
第2分钟了解!微乐小程序辅助器... 第2分钟了解!微乐小程序辅助器,熊猫辅助器视频教程,妙计教程(竟然有挂)-哔哩哔哩熊猫辅助器视频教程...
三分钟了解!威信茶馆解码器,闲... 三分钟了解!威信茶馆解码器,闲来辅助软件靠谱吗,策略教程(发现有挂)-哔哩哔哩1、许多玩家不知道闲来...
两分钟了解!老k游戏辅助器,福... 两分钟了解!老k游戏辅助器,福建微乐小程序修改器,要领教程(有挂教程)-哔哩哔哩1、不需要AI权限,...
七分钟了解!黑科技微乐小程序辅... 七分钟了解!黑科技微乐小程序辅助器免费,白金岛跑胡子脚本,指南教程(有挂工具)-哔哩哔哩黑科技微乐小...