【网格问题】leetcode1020.飞地的数量

2023-11-19

题目:
给你一个大小为 m x n 的二进制矩阵 grid ,其中 0 表示一个海洋单元格、1 表示一个陆地单元格。

一次 移动 是指从一个陆地单元格走到另一个相邻(上、下、左、右)的陆地单元格或跨过 grid 的边界。

返回网格中 无法 在任意次数的移动中离开网格边界的陆地单元格的数量。
在这里插入图片描述

在这里插入图片描述
解答:
方法一:BFS

class Solution:
    def numEnclaves(self, grid: List[List[int]]) -> int:
        #BFS
        m=len(grid)
        n=len(grid[0])
        directions=[[-1,0],[1,0],[0,-1],[0,1]]
        q=deque()
        
        #左右边界
        for i in range(m):
            if grid[i][0]==1:
                q.append((i,0))
                grid[i][0]=2
            if grid[i][n-1]==1:
                q.append((i,n-1))
                grid[i][n-1]=2
        #上下边界
        for j in range(1,n-1):
            if grid[0][j]==1:
                q.append((0,j))
                grid[0][j]=2
            if grid[m-1][j]==1:
                q.append((m-1,j))
                grid[m-1][j]=2
        
        def InArea(i,j):
            if 0<=i<m and 0<=j<n:
                return True
            return False
        
        #从边界上的陆地单元格出发,标记与其直接或间接相连的单元格
        while q:
            x,y=q.popleft()
            for dx,dy in directions:
                curx,cury=x+dx,y+dy
                if InArea(curx,cury) and grid[curx][cury]==1:
                    q.append((curx,cury))
                    grid[curx][cury]=2
        
        res=0
        for i in range(1,m-1):
            for j in range(1,n-1):
                if grid[i][j]==1:
                    res+=1
        return res

方法二:DFS

class Solution:
    def numEnclaves(self, grid: List[List[int]]) -> int:
        #DFS
        m=len(grid)
        n=len(grid[0])
        directions=[[-1,0],[1,0],[0,-1],[0,1]]        
        
        def InArea(i,j):
            if 0<=i<m and 0<=j<n:
                return True
            return False

        def dfs(i,j):
            if not InArea(i,j) or grid[i][j]!=1:
                return
            #将其标记为已访问
            grid[i][j]=2
            for dx,dy in directions:
                dfs(i+dx,j+dy)            
                                
        #左右边界
        for i in range(m):
            dfs(i,0)
            dfs(i,n-1)
        #上下边界
        for j in range(1,n-1):
            dfs(0,j)
            dfs(m-1,j)
        
        res=0
        for i in range(1,m-1):
            for j in range(1,n-1):
                if grid[i][j]==1:
                    res+=1
        return res
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

【网格问题】leetcode1020.飞地的数量 的相关文章

随机推荐

  • chatgpt赋能Python-python_3__3

    Python 3 3 深入探讨Python中的相等运算符 在Python中 我们经常需要比较两个值是否相等 而Python的相等运算符 是用来判断两个值是否相等 在这篇文章中 我们将深入探讨Python中的 运算符 两个等号的作用 在Pyt
  • Maven 项目打包源文件 *-sources.jar

    在 pom xml 配置文件中添加以下插件
  • 瑞数信息联合中国信通院发布《云上WAAP发展洞察报告(2023)》

    8月25日 由中国信息通信研究院 以下简称 中国信通院 和中国通信标准化协会联合主办的 2023云和软件安全大会 在北京召开 会上 瑞数信息与中国信通院云计算与大数据研究所联合撰写的 云上WAAP发展洞察报告 2023 以下简称 报告 正式
  • 区块链能够解决价值对等问题吗?

    如果说互联网让信息透明和平等 降低或者使得获取信息成本为零 那么区块链则是让价值更公平 原因在于区块链技术的去中心化与分布式数据存储 一般来说 商业进化需经历三个阶段 由PC互联网 移动互联网所控制的信息互联网 称为第一阶段 由物联网 人工
  • Lottie动画概述,文末有彩蛋

    原生的动画效果有时候写起来会非常的复杂 要考虑到很多兼容和效果 Lottie动画专门为了解决这种烦恼而产生的 注 不仅是Lottie可以做到 另外一种库也可以做到将动画分成一帧一帧展示 它就是 android gif drawable 库
  • Dynamics 365 Business Process Flow -- 让你不再惧怕复杂的业务流程!

    Business Process Flow 并不是新功能 它最初是在Dynamics CRM 2013中被发布的 刚推出的时候 用户体验和开发体验并不是非常的完善 随着版本的不断迭代 新功能也不断的被增加 特别是在最近发布的Dynamics
  • AIX系统解压tar.gz文件

    gunzip c apache tar gz tar xvf
  • C++ 如何将一个大的整数 拆分0到9单个数字

    如何将一个大的整数拆分成单个整数 第一种解决方案 第二种解决方案 分享思路 希望能帮到你 第一种解决方案 纯算法的方式 完整数 int value 123456 拆分后的个位数 int sub 拆分 while value 得到当前整数 尾
  • ORB-SLAM3---imu相关

    1 IMU简介及参数说明 2 预积分推导 纸老虎 1 反对称矩阵 2 反对称矩阵反过来 3 旋转向量到旋转矩阵 上面是积分 下面是预积分 3 噪声分离
  • 【超详细!】Snort在Win-7下的安装配置及可视化

    做学校实验做到秃头的产物 记录一下我一边考试一边实验的疯狂期末周 前排提示本人是个看到修改一大堆配置就头疼的菜狗 所以这篇教程尽可能减少了修改配置 包含了本人遇到的坑 解决方案 我尽力了朋友们 一 前期资源准备 1 win 7环境虚拟机 这
  • JavaScript常见调试方法

    编辑导语 javascript调试方法 常见使用alert和console来定位出错和输出的结果是否是想要的 在chrome中 还可以使用断点来看运行的情况等 本文介绍了比较全面的调试方法 你知道console table console
  • 虚函数与纯虚函数定义及区别,抽象类

    目录 虚函数和纯虚函数的区别 二 虚函数的实现机制 三 构造函数 析构函数是否需要定义成虚函数 四 构造函数和析构函数中能否调用虚函数 虚函数与纯虚函数定义 一 定义虚函数 被 virtual 关键字修饰的成员函数 纯虚函数 在类中声明虚函
  • vant4 自定义垂直步骤条时间线组件几行css代码改造完成(附效果图)

    直接上效果图片
  • Android模拟器的ip获取以及模拟器之间socket通信

    作者 李波 实现网络五子棋时用到了两个设备间的Socket通信 如果使用真机调试比较麻烦 用两个模拟器之间进行通信会比较方便 首先要获得的模拟器的IP地址 在本机上启动两个模拟器 emulator 5554 emulator 5556查看模
  • Vulhub Nginx 文件名逻辑漏洞复现

    漏洞介绍 漏洞编号 CVE 2013 4547 漏洞原理 Nginx 在遇到 00 空字节 时 与后端 FastCGI 处理不一致 导致可以在图片中嵌入 PHP 代码 然后通过访问 xxx jpg 00 php 来执行其中的代码 影响版本
  • node常用指令

    node 进入node运行环境 node v 查看node的版本 node 文件名 使用node环境运行js文件 ctrl c 退出指令 cd 返回上一级路径 cd 文件夹名 进入当前目录的某个文件夹 dir 显示当前目录下的所有的文件夹和
  • 2021-06-15——这56个免费资源网站,能让你永久告别资源付费!

    一 视频类 1 预告片世界 https www yugaopian cn 2 33台词 http 33 agilestudio cn 3 MixKit https mixkit co free stock video 4 Pexel htt
  • 解决idea运行springboot项目,项目不运行在Run Dashboard

    今天在运行项目时 发现项目没有自动运行在run dashboard面板中 而是在run面板中运行 解决方案 1 点击编辑configurations 2 首先在Application中选中你需要添加的项目 点击加号 选springboot
  • 基于SpringBoot实现人脸识别功能

    前言 去年在公司参与了一个某某机场建设智能机场的一个项目 人脸登机是其中的一个功能模块 当时只是写了后台的接口 调用人脸识别设备的api 给闸机回传数据信号 以保障该功能的正常使用 当时因为项目进度紧张 手里还有其他项目赶进度 也就没时间去
  • 【网格问题】leetcode1020.飞地的数量

    题目 给你一个大小为 m x n 的二进制矩阵 grid 其中 0 表示一个海洋单元格 1 表示一个陆地单元格 一次 移动 是指从一个陆地单元格走到另一个相邻 上 下 左 右 的陆地单元格或跨过 grid 的边界 返回网格中 无法 在任意次