计数子岛

1905 年。计算子岛屿

难度:中等

主题:数组、深度优先搜索、广度优先搜索、并集查找、矩阵

给定两个 m x n 二进制矩阵 grid1 和 grid2,其中仅包含 0(代表水)和 1(代表土地)。 岛屿是一组由1连接的4向(水平或垂直)。网格之外的任何细胞都被视为水细胞。

如果 grid1 中的一个岛包含所有构成 grid2 中这个岛的单元格,则 grid2 中的岛被视为子岛 .

返回grid2中被视为子岛数量个岛屿。

示例1:

计数子岛

输入: grid1 = [[1,1,1,0,0],[0,1,1,1,1],[0,0,0,0,0],[1, 0,0,0,0],[1,1,0,1,1]], grid2 = [[1,1,1,0,0],[0,0,1,1,1],[ 0,1,0,0,0],[1,0,1,1,0],[0,1,0,1,0]]输出: 3说明: 上图中,左边的网格是grid1,右边的网格是grid2。grid2 中红色的 1 被认为是子岛的一部分。共有三个子岛。

示例2:

计数子岛

输入: grid1 = [[1,0,1,0,1],[1,1,1,1,1],[0,0,0,0,0],[1, 1,1,1,1],[1,0,1,0,1]], grid2 = [[0,0,0,0,0],[1,1,1,1,1],[ 0,1,0,1,0],[0,1,0,1,0],[1,0,0,0,1]]输出: 2说明: 上图中,左边的网格是grid1,右边的网格是grid2。grid2 中红色的 1 被认为是子岛的一部分。有两个子岛。

约束:

m == grid1.length == grid2.lengthn == grid1[i].length == grid2[i].length1 grid1[i][j] 和 grid2[i][j] 为 0 或 1。

提示:

让我们使用洪水填充来迭代第二个网格的岛屿让我们注意,如果第二个网格中的一个岛上的所有单元格都由第一个网格中的土地表示,那么它们就会连接起来,从而使该岛成为一个子岛

解决方案:

我们将使用深度优先搜索 (dfs) 方法来探索 grid2 中的岛屿,并检查每个岛屿是否完全包含在 grid1 中的相应岛屿内。以下是我们实施该解决方案的方法:

步骤:

遍历网格:我们将迭代 grid2 中的每个单元格。识别 grid2 中的岛屿:当我们在 grid2 中遇到陆地单元 (1) 时,我们将使用 dfs 探索整个岛屿。检查子岛情况: 在 grid2 中的一个岛屿上执行 dfs 时,我们将检查 grid1 中所有对应的单元格是否也是陆地单元格。如果是的话,该岛就是一个子岛。计算子岛数: 对于 grid2 中满足子岛条件的每个岛屿,我们将增加子岛数。

让我们用 php 实现这个解决方案:1905。数一下子岛屿


解释:

dfs 函数: dfs 函数探索 grid2 中的岛屿,并检查 grid1 中相应的单元格是否都是陆地单元格。如果 grid2 中的任何单元格是陆地,但 grid1 中相应的单元格是水,则 grid2 中的岛屿不是子岛。标记已访问: 当我们遍历 grid2 时,我们通过将单元格设置为 0 将其标记为已访问。主循环:我们迭代grid2中的所有单元格。每当我们发现一个尚未访问过的陆地单元时,我们都会启动 dfs 来检查它是否是子岛的一部分。

时间复杂度:

时间复杂度为 (o(m × n)),其中 m 是行数,n 是列数。这是因为我们可能会访问每个单元格一次。

该解决方案应该在给定的限制内有效地工作。

联系链接

如果您发现本系列有帮助,请考虑在 github 上给存储库 一个星星,或在您最喜欢的社交网络上分享该帖子?。您的支持对我来说意义重大!

如果您想要更多类似的有用内容,请随时关注我:

领英github

以上就是计数子岛的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1245691.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月9日 17:56:31
下一篇 2025年12月9日 17:56:41

相关推荐

  • PHP 函数性能优化中的基准测试实践

    基准测试对于评估和优化 php 函数性能至关重要,涉及测量执行时间并进行改进。最佳实践包括使用基准测试库、运行多次测试、使用适当数据集、控制环境和比较不同实现。实战案例中,strcmp_bin 比strcmp和strcasecmp快几个数量级,因为它进行二进制比较。 PHP 函数性能优化中的基准测试…

    2025年12月9日
    000
  • PHP 函数命名与版本控制和持续集成

    PHP 函数命名与版本控制和持续集成 PHP 函数的命名是其设计和可维护性的关键方面。遵循明确的命名约定有助于提高代码的易读性和可理解性,从而使协作和维护变得更加容易。 命名约定 以下是一些常用的 PHP 函数命名约定: 立即学习“PHP免费学习笔记(深入)”; 首字母小写,驼峰式写法(小驼峰形式)…

    2025年12月9日
    000
  • PHP 函数参数绑定与数据验证的关系?

    函数参数绑定关联参数值和数据类型,而数据验证确保参数符合格式和值。它们协同工作,通过强制类型和验证传入值,提高代码的可读性、可维护性和安全性。 PHP 函数参数绑定与数据验证的关系 简介 在 PHP 函数中,参数绑定是一种将参数值与其数据类型相关联的技术。此技术有助于提高代码的可读性、可维护性和安全…

    2025年12月9日
    000
  • 防止 PHP 递归函数堆栈溢出的最佳实践

    php 递归函数堆栈溢出可通过以下最佳实践预防:设置递归深度限制、使用尾调用优化和循环代替递归。例如,使用以下代码计算斐波那契数列:设置递归深度限制:ini_set(‘recursion_limit’, 100);使用尾调用优化:function fibonaccitail(…

    2025年12月9日
    000
  • 使用迁移在 Laravel 中进行数据库架构管理:深入教程

    laravel 迁移是管理数据库架构更改的好方法。它们允许您对数据库结构进行版本控制,并随时间轻松回滚或修改更改。在本指南中,我们将逐步探索在 laravel 中创建、运行和回滚迁移的过程,并提供一个实践示例。 第 1 步:设置 laravel 环境 开始迁移之前,请确保已安装 laravel。您可…

    2025年12月9日
    000
  • 用 PHP 构建 Pokémon API:初学者指南

    在本指南中,我们将逐步完成创建一个基本 php 项目的步骤,该项目将 pokémon api 与 flight 框架以及 zebra_curl 和 latte 等附加包结合使用。我们将探索设置项目、添加路线和渲染视图。 tl;dr:在 flight 中制作一个简单的基于 api 的项目并不难。查看本…

    2025年12月9日
    000
  • 优化大规模 API 数据检索:最佳实践和 PHP 延迟收集解决方案

    当使用 api 检索大量数据(可能是数千个项目)时,需要考虑几个关键方面,以确保流程高效、灵活且高性能。以下是需要管理的关键因素的细分,以及针对 php 用户的解决方案。 通过 api 检索大数据时的关键注意事项 让我分享一些通过 api 高效检索大型数据集的关键注意事项: 处理分页:api 通常在…

    2025年12月9日
    000
  • 在 Mageia 9 上安装 ASDF

    今天我们要在 Mageia 9 上安装 ASDF。接下来的步骤是将插件安装到 PHP 和 Node.js。 要在版本 0.14.1 上安装 ASDF,我使用了 Git + ZSH 版本: #%#$#%@%@%$#%$#%#%#$%@_ba9f11ec++3497d9993b933fdc2bd61e5…

    2025年12月9日
    000
  • 小型机械手

    小班机械手新的主要版本 代码已完全重构并编码为属性操作的新支持 这是一个操纵示例: $classFile = SmallClassManipulatorClassManipulator::fromProject(__DIR__ . ‘/../..’) ->getClass(SmallClass…

    2025年12月9日
    000
  • 将数组转换为数组

    2022 年。将一维数组转换为二维数组 难度:简单 主题:数组、矩阵、模拟 给你一个0索引一维(1d)整数数组原始,和两个整数,m和n。您的任务是使用原始数据中的所有元素创建一个包含 m 行和 n 列的二维 (2d) 数组。 原始索引从0到n – 1(包括)的元素应该形成构造的二维数组的…

    2025年12月9日
    000
  • 转换后字符串的数字总和

    1945 年。转换后字符串的数字总和 难度:简单 主题:字符串、模拟 给你一个由小写英文字母组成的字符串 s 和一个整数 k。 首先,将 s 转换为整数,方法是将每个字母替换为其在字母表中的位置(即,将 ‘a’ 替换为 1,将 ‘b’ 替换为 2,&#…

    2025年12月9日
    000
  • 关于 PHP 代码安全性您应该了解的内容

    在 web 开发方面,php 是一种广泛使用的脚本语言。随着 php 的流行,了解与 php 相关的潜在安全风险以及缓解这些风险的措施至关重要。无论您使用 wordpress 部署 cms 应用程序还是使用 laravel php 框架构建企业应用程序,php 安全性的重要性以及一些值得注意的 ph…

    2025年12月9日
    000
  • 找到将更换粉笔的学生

    1894。找到将替换粉笔的学生 难度:中等 主题:数组、二分查找、模拟、前缀和 一个班级有n个学生,编号从0到n – 1。老师会给每个学生一个问题,从学号0开始,然后是学号1,以此类推,直到老师达到学号n – 1. 之后,老师将重新开始该过程,再次从学号0开始。 给你一个0索…

    2025年12月9日
    000
  • 连接两组点的最低成本

    1595。连接两组点的最低成本 难度:难 主题:数组、动态规划、位操作、矩阵、位掩码 给你两组点,第一组有大小1点,第二组有大小2点,大小1 >=尺寸2. 任意两点之间的连接成本以大小 1 x size2 矩阵给出,其中 cost[i][j] 是连接点 i 的成本第一组和第二组的 j 点。如果…

    2025年12月9日
    000
  • 修改图边权重

    2699。修改图边权重 难度:难 主题:图、堆(优先级队列)、最短路径 给你一个无向加权连通图,其中包含标记为0到n – 1的n个节点,以及一个整数数组edges,其中edges[i] = [ai, b i, wi] 表示节点 ai 和 bi 之间有一条边,权重为 wi. 某些边的权重为…

    2025年12月9日
    000
  • 为什么一些开发人员更喜欢手动配置 PHP 环境而不是使用部署工具

    在现代软件开发中,php 是一种广泛使用的编程语言。然而,对于许多开发人员来说,搭建 php 环境并不是一件容易的事。手动配置php环境通常涉及多个复杂的步骤,包括安装php解释器、配置web服务器(例如apache或nginx)、设置数据库(例如mysql或postgresql)以及管理各种扩展模…

    2025年12月9日
    000
  • 同一行或同一列移除的大部分石头

    947。同一行或同一列移除的大部分石头 难度:中等 主题:哈希表、深度优先搜索、并集查找、图 在 2d 平面上,我们将 n 个石头放置在一些整数坐标点处。每个坐标点最多可以有一颗石头。 如果一块石头与另一块尚未移除的石头同一行或同一列,则可以将其移除。 给定一个长度为 n 的石头数组,其中stone…

    2025年12月9日
    000
  • 具有最大概率的路径

    1514。具有最大概率的路径 难度:中等 主题:数组、图、堆(优先队列)、最短路径 给定一个由 n 个节点(0 索引)组成的无向加权图,由边列表表示,其中edges[i] = [a, b] 是连接节点 a 和 b 的无向边,具有遍历成功的概率该边 succprob[i]. 给定两个节点的起点和终点,…

    2025年12月9日
    000
  • 掌握 PHP 和 MySQL:现代开发人员的详尽指南

    掌握 php 和 mysql:现代开发人员的详尽指南 ? php 和 mysql 构成了许多动态网站和 web 应用程序的支柱。该综合指南涵盖了先进概念、最佳实践和现代工具,可帮助开发人员充分利用这些技术的潜力。通过详细信息和实用技巧深入了解 php 和 mysql。 1. php 和 mysql …

    2025年12月9日
    000
  • PHP 函数如何创建可迭代和可遍历的对象?

    答案: 使用 php 函数创建可迭代和可遍历对象可简化数据遍历。详细描述:可迭代对象: 使用 range() 和 array() 函数创建可迭代对象,可按顺序访问元素。可遍历对象: 使用 arrayiterator() 和 cachingiterator() 函数创建可遍历对象,可使用 foreac…

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信