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.mzph.cn/news/1215443.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2026 年 1 月珠海烟酒礼品回收厂家推荐榜单:茅台/洋酒/冬虫夏草/燕窝鱼胶等名品高价回收,专业可靠、快捷变现之选

2026 年 1 月珠海烟酒礼品回收厂家推荐榜单:茅台/洋酒/冬虫夏草/燕窝鱼胶等名品高价回收,专业可靠、快捷变现之选 随着社会经济活动的日益频繁和消费观念的不断升级,礼品馈赠已成为商务往来与情感维系的重要纽带。随…

MinIO替代方案安全性对比:RustFS如何为数据筑牢防护墙?

MinIO替代方案安全性对比:RustFS如何为数据筑牢防护墙? 存储安全的核心不是“功能多全”,而是“方案能匹配自身风险,且团队能落地执行”——MinIO迁移时,很多团队陷入“追全量安全功能”的误区,最终要么因配置复…

HCIP笔记6--OSPF域外路由、特殊区域(stub、totally stub) - 指南

HCIP笔记6--OSPF域外路由、特殊区域(stub、totally stub) - 指南2026-01-25 18:57 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !i…

快捷键:Ctrl+Shift+P打开命令面板

核心作用命令面板相当于一个 “功能总菜单”&#xff0c;你可以通过输入关键词快速搜索并执行 VS Code 的所有功能&#xff0c;无需在各级菜单中点击查找&#xff0c;大幅提升操作效率。常见用途&#xff08;结合你的 ESP32 开发场景&#xff09;执行开发命令&#xff1a;输入E…

内存-磁盘

1. DRAM内存 - dynamic random access memory&#xff0c;动态随机存取存取器2. L2二级缓存 - Level 2 cache3. SLC系统级缓存 - System Level cache&#xff0c;也常称为三级缓存 (L3 Cache)4. VRAM显存 - video random access memory&#xff0c;视频随机存取存储器5. GMEM -…

硬件异构性-cpu-gpu-npu

npu简介&#xff1a;https://www.zhihu.com/question/346062227 高通骁龙命令规则&#xff1a;https://zhuanlan.zhihu.com/p/1979915511929275517

[驱动进阶——MIPI摄像头驱动(三)]rk3588+OV13855摄像头驱动加载过程详细解析第二部分——DPHY驱动+CSI驱动

上一篇文章已经讲解过摄像头数据流动环节的第一部分——sensor驱动&#xff0c;接下来进行剩余部分的讲解&#xff0c;本篇文章进行DPHY驱动和CSI驱动加载过程的解析&#xff1a;Sensor (OV13855) ➔ DPHY (物理层) ➔ CSI Host (控制器) ➔ VICAP(CIF) ➔ ISP驱动源码解析&…

Java 后端开发中 Service 层依赖注入的最佳实践:Mapper 还是其他 Service?

前言 在 Java 后端开发中&#xff0c;采用经典的三层架构&#xff08;Controller - Service - DAO/Mapper&#xff09;是业界广泛接受的工程实践。这种分层结构通过职责分离&#xff0c;提升了代码的可维护性、可测试性和可扩展性。 然而&#xff0c;在实际开发过程中&#xff…

[驱动进阶——MIPI摄像头驱动(四)]rk3588+OV13855摄像头驱动加载过程详细解析第三部分——CIF驱动+SDITF驱动

上一篇文章已经讲解过摄像头数据流动环节的第二部分——DPHY驱动CSI驱动&#xff0c;接下来进行剩余部分的讲解&#xff0c;本篇文章进行CIF驱动SDITF驱动加载过程的解析&#xff1a;Sensor (OV13855) ➔ DPHY (物理层) ➔ CSI Host (控制器) ➔ VICAP(CIF) ➔ ISPSDITF是依附于…

2026 年 1 月铝材加工设备与材料厂家推荐榜单:压块机、铝棒、铝管、研磨铝棒管、挤压棒、铝合金,飞象精铝等源头实力厂家全景解析

2026 年 1 月铝材加工设备与材料厂家推荐榜单:压块机、铝棒、铝管、研磨铝棒管、挤压棒、铝合金,飞象精铝等源头实力厂家全景解析 随着高端制造业向精密化、智能化方向持续演进,铝材作为现代工业的“骨骼”与“肌肉…

基于机器学习的道路交通状态分析(代码+报告+数据)(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

基于机器学习的道路交通状态分析(代码报告数据)(设计源文件万字报告讲解)&#xff08;支持资料、图片参考_相关定制&#xff09;_文章底部可以扫码1、本项目利用关联规则算法挖掘分析影响交通状况的原因&#xff0c;再利用随机森林算法完成交通状况预测。 2、由于计算机科学的快…

我们将讨论如何在 React 中使用表单单元素与 Reac

React 表单与事件 本章节我们将讨论如何在 React 中使用表单。 HTML 表单元素与 React 中的其他 DOM 元素有所不同,因为表单元素生来就保留一些内部状态。 在 HTML 当中&#xff0c;像 <input>, <textarea>, 和 <select> 这类表单元素会维持自身状态&…

数据变化(原始数据—数据清洗—特征工程)

数据清洗步骤 用户行为数据缺失值处理 user_id、item_id是关联用户和商品的唯一标识&#xff0c;缺失后无法建立有效关联behavior_type是核心行为标签&#xff0c;缺失无法定义交互类型timestamp是时间序列分析的基础&#xff0c;缺失影响序列特征的准确性直接删除比填充更可靠…

Emacs 折腾日记(三十五)——归档

在前几篇文章中,我们经历了 GTD 流程中的收集想法、制定计划、以及执行和记录计划的过程,现在我们继续后续的流程,也就是最后的回顾和归档。 当日回顾 在我个人实践 GTD 的流程中,前一晚会做这些事情:回顾一下今天…

2026 年 1 月投饵船厂家推荐排行榜,无人投饵船,自动投饵船,遥控投饵船,智能投料船,水产养殖自动化精准投喂解决方案精选

2026年1月投饵船厂家推荐排行榜:水产养殖自动化精准投喂解决方案精选 随着全球水产养殖业向集约化、智能化方向加速转型,传统依赖人工作业的投喂模式正面临效率瓶颈、成本高企与精准度不足等多重挑战。在此背景下,以…

2026 年 1 月液相色谱厂家推荐排行榜,色谱柱/液相色谱仪/二维液相色谱/UPLC/制备液相色谱,精准分离分析技术源头实力解析

2026 年 1 月液相色谱厂家推荐排行榜:色谱柱/液相色谱仪/二维液相色谱/UPLC/制备液相色谱,精准分离分析技术源头实力解析 在生命科学、药物研发、食品安全、环境监测等众多前沿与基础研究领域,液相色谱技术作为不可…

xFUZZ: A Flexible Framework for Fine-Grained, Runtime-Adaptive Fuzzing Strategy Composition

概要:现有灰盒模糊测试工具要么策略固定、要么只能整工具切换,无法随目标程序和测试阶段 的变化而细粒度、运行时地调整策略;我们提出 xFUZZ,首次把输入调度、变异调度等核 心组件全部做成可热插拔的插件,并用滑动…

2026 年 1 月古建瓦厂家推荐排行榜,中式古建瓦,园林古建瓦,仿古瓦定制,古建瓦供应,匠心传承与建筑美学融合之选

2026年1月古建瓦厂家推荐排行榜:中式古建瓦、园林古建瓦、仿古瓦定制与供应的匠心之选 在当代建筑文化复兴与文旅产业蓬勃发展的浪潮下,古建瓦作为承载中式建筑灵魂的重要构件,其市场需求持续升温。无论是历史古迹的…