当前位置: 首页 > news >正文

Day52 >> 101、孤岛的总面积 + 102、沉默孤岛 + 103、水流问题 + 104、建造最大岛屿

代码随想录-图论Part3

101、孤岛的总面积

package test.java; import java.util.*; public class dfsPart3 { private static int count = 0; private static final int[][] dir = {{0, 1}, {1, 0}, {-1, 0}, {0, -1}}; private static void bfs(int[][] grid, int x, int y) { Queue<int[]> que = new LinkedList<>(); que.add(new int[]{x, y}); grid[x][y] = 0; // 只要加入队列,立刻标记 count++; while (!que.isEmpty()) { int[] cur = que.poll(); int curx = cur[0]; int cury = cur[1]; for (int i = 0; i < 4; i++) { int nextx = curx + dir[i][0]; int nexty = cury + dir[i][1]; if (nextx < 0 || nextx >= grid.length || nexty < 0 || nexty >= grid[0].length) continue; // 越界了,直接跳过 if (grid[nextx][nexty] == 1) { que.add(new int[]{nextx, nexty}); count++; grid[nextx][nexty] = 0; // 只要加入队列立刻标记 } } } } public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); int m = scanner.nextInt(); int[][] grid = new int[n][m]; // 读取网格 for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { grid[i][j] = scanner.nextInt(); } } // 从左侧边,和右侧边向中间遍历 for (int i = 0; i < n; i++) { if (grid[i][0] == 1) bfs(grid, i, 0); if (grid[i][m - 1] == 1) bfs(grid, i, m - 1); } // 从上边和下边向中间遍历 for (int j = 0; j < m; j++) { if (grid[0][j] == 1) bfs(grid, 0, j); if (grid[n - 1][j] == 1) bfs(grid, n - 1, j); } count = 0; for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { if (grid[i][j] == 1) bfs(grid, i, j); } } System.out.println(count); scanner.close(); } }

102、沉默孤岛

package test.java; import java.util.Scanner; public class dfsPart4 { static int[][] dir = { {-1, 0}, {0, -1}, {1, 0}, {0, 1} }; // 保存四个方向 public static void dfs(int[][] grid, int x, int y) { grid[x][y] = 2; for (int[] d : dir) { int nextX = x + d[0]; int nextY = y + d[1]; // 超过边界 if (nextX < 0 || nextX >= grid.length || nextY < 0 || nextY >= grid[0].length) continue; // 不符合条件,不继续遍历 if (grid[nextX][nextY] == 0 || grid[nextX][nextY] == 2) continue; dfs(grid, nextX, nextY); } } public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); int m = scanner.nextInt(); int[][] grid = new int[n][m]; for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { grid[i][j] = scanner.nextInt(); } } // 步骤一: // 从左侧边,和右侧边 向中间遍历 for (int i = 0; i < n; i++) { if (grid[i][0] == 1) dfs(grid, i, 0); if (grid[i][m - 1] == 1) dfs(grid, i, m - 1); } // 从上边和下边 向中间遍历 for (int j = 0; j < m; j++) { if (grid[0][j] == 1) dfs(grid, 0, j); if (grid[n - 1][j] == 1) dfs(grid, n - 1, j); } // 步骤二、步骤三 for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { if (grid[i][j] == 1) grid[i][j] = 0; if (grid[i][j] == 2) grid[i][j] = 1; } } for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { System.out.print(grid[i][j] + " "); } System.out.println(); } scanner.close(); } }

103、水流问题

这道太难了……后续再练习吧

104、建造最大岛屿

package test.java; import java.util.HashMap; import java.util.HashSet; import java.util.Scanner; public class dfsPart5 { // 该方法采用 DFS // 定义全局变量 // 记录每次每个岛屿的面积 static int count; // 对每个岛屿进行标记 static int mark; // 定义二维数组表示四个方位 static int[][] dirs = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}}; // DFS 进行搜索,将每个岛屿标记为不同的数字 public static void dfs(int[][] grid, int x, int y, boolean[][] visited) { // 当遇到边界,直接return if (x < 0 || x >= grid.length || y < 0 || y >= grid[0].length) return; // 遇到已经访问过的或者遇到海水,直接返回 if (visited[x][y] || grid[x][y] == 0) return; visited[x][y] = true; count++; grid[x][y] = mark; // 继续向下层搜索 dfs(grid, x, y + 1, visited); dfs(grid, x, y - 1, visited); dfs(grid, x + 1, y, visited); dfs(grid, x - 1, y, visited); } public static void main (String[] args) { Scanner sc = new Scanner(System.in); int m = sc.nextInt(); int n = sc.nextInt(); int[][] grid = new int[m][n]; for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { grid[i][j] = sc.nextInt(); } } // 初始化mark变量,从2开始(区别于0水,1岛屿) mark = 2; // 定义二位boolean数组记录该位置是否被访问 boolean[][] visited = new boolean[m][n]; // 定义一个HashMap,记录某片岛屿的标记号和面积 HashMap<Integer, Integer> getSize = new HashMap<>(); // 定义一个HashSet,用来判断某一位置水四周是否存在不同标记编号的岛屿 HashSet<Integer> set = new HashSet<>(); // 定义一个boolean变量,看看DFS之后,是否全是岛屿 boolean isAllIsland = true; // 遍历二维数组进行DFS搜索,标记每片岛屿的编号,记录对应的面积 for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { if (grid[i][j] == 0) isAllIsland = false; if (grid[i][j] == 1) { count = 0; dfs(grid, i, j, visited); getSize.put(mark, count); mark++; } } } int result = 0; if (isAllIsland) result = m * n; // 对标记完的grid继续遍历,判断每个水位置四周是否有岛屿,并记录下四周不同相邻岛屿面积之和 // 每次计算完一个水位置周围可能存在的岛屿面积之和,更新下result变量 for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { if (grid[i][j] == 0) { set.clear(); // 当前水位置变更为岛屿,所以初始化为1 int curSize = 1; for (int[] dir : dirs) { int curRow = i + dir[0]; int curCol = j + dir[1]; if (curRow < 0 || curRow >= m || curCol < 0 || curCol >= n) continue; int curMark = grid[curRow][curCol]; // 如果当前相邻的岛屿已经遍历过或者HashMap中不存在这个编号,继续搜索 if (set.contains(curMark) || !getSize.containsKey(curMark)) continue; set.add(curMark); curSize += getSize.get(curMark); } result = Math.max(result, curSize); } } } System.out.println(result); sc.close(); } }
http://www.jsqmd.com/news/299223/

相关文章:

  • 2026 年 1 月珠海烟酒礼品回收厂家推荐榜单:茅台/洋酒/冬虫夏草/燕窝鱼胶等名品高价回收,专业可靠、快捷变现之选
  • MinIO替代方案安全性对比:RustFS如何为数据筑牢防护墙?
  • HCIP笔记6--OSPF域外路由、特殊区域(stub、totally stub) - 指南
  • 快捷键:Ctrl+Shift+P打开命令面板
  • 内存-磁盘
  • 硬件异构性-cpu-gpu-npu
  • [驱动进阶——MIPI摄像头驱动(三)]rk3588+OV13855摄像头驱动加载过程详细解析第二部分——DPHY驱动+CSI驱动
  • Java 后端开发中 Service 层依赖注入的最佳实践:Mapper 还是其他 Service?
  • [驱动进阶——MIPI摄像头驱动(四)]rk3588+OV13855摄像头驱动加载过程详细解析第三部分——CIF驱动+SDITF驱动
  • 2026 年 1 月铝材加工设备与材料厂家推荐榜单:压块机、铝棒、铝管、研磨铝棒管、挤压棒、铝合金,飞象精铝等源头实力厂家全景解析
  • 基于机器学习的道路交通状态分析(代码+报告+数据)(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • 我们将讨论如何在 React 中使用表单单元素与 Reac
  • 数据变化(原始数据—数据清洗—特征工程)
  • Emacs 折腾日记(三十五)——归档
  • 2026 年 1 月投饵船厂家推荐排行榜,无人投饵船,自动投饵船,遥控投饵船,智能投料船,水产养殖自动化精准投喂解决方案精选
  • 2026 年 1 月液相色谱厂家推荐排行榜,色谱柱/液相色谱仪/二维液相色谱/UPLC/制备液相色谱,精准分离分析技术源头实力解析
  • xFUZZ: A Flexible Framework for Fine-Grained, Runtime-Adaptive Fuzzing Strategy Composition
  • The 45th ICPC Asia East Continent Final Contest部分题解
  • 2026 年 1 月古建瓦厂家推荐排行榜,中式古建瓦,园林古建瓦,仿古瓦定制,古建瓦供应,匠心传承与建筑美学融合之选
  • 5846345645
  • 624524
  • 【VLM】Visual Merit or Linguistic Crutch? 看DeepSeek-OCR
  • Go进阶之反射
  • 2026 年 1 月仿古瓦厂家推荐排行榜,中式仿古瓦,小青瓦仿古瓦,定制仿古瓦,古建屋面瓦公司推荐,甄选匠心工艺与耐久品质!
  • .bat脚本新建文件夹【项目结构】
  • 2026 年 1 月工业醇类及溶剂厂家推荐榜单:乙醇/无水乙醇/二丙酮醇/异丙醇/乙二醇/正丁醇/工业酒精/甲醇/醇酸漆稀释剂/丙二醇甲醚等源头实力厂家精选
  • 2025年教我学英语 - 穿、衣
  • 探索Matlab水下图像处理与GUI界面构建之旅
  • 快过年了 , 我就简简单单写一个总结吧 ! | 马年快乐 !
  • FPGA FFT缩放因子配置全解析