代码随想录算法训练营Day 62| 图论 part02 | 695. 岛屿的最大面积、1020.飞地的数量、130.被围绕的区域

代码随想录算法训练营Day 62| 图论 part02 | 695. 岛屿的最大面积、1020.飞地的数量、130.被围绕的区域


文章目录

  • 代码随想录算法训练营Day 62| 图论 part02 | 695. 岛屿的最大面积、1020.飞地的数量、130.被围绕的区域
  • 65.岛屿的最大面积
    • 一、BFS
    • 二、DFS
  • 1020.飞地的数量
    • 一、DFS
    • 二、BFS
    • 三、本题总结
  • 130.被围绕的区域
    • 一、DFS


65.岛屿的最大面积

题目链接

一、BFS

class Solution(object):def maxAreaOfIsland(self, grid):""":type grid: List[List[int]]:rtype: int"""# BFSm,n = len(grid),len(grid[0])visited = [[False]*n for _ in range(m)]dirs = [(-1,0),(0,1),(1,0),(0,-1)]maxres = 0def bfs(i,j):q = collections.deque()q.append((i,j))visited[i][j]=Truecount=1while q:x,y = q.popleft()for d in dirs:nextx = x+d[0]nexty = y+d[1]if nextx<0 or nextx>=m or nexty<0 or nexty>=n:continueif visited[nextx][nexty] or grid[nextx][nexty]==0:continueq.append((nextx,nexty))visited[nextx][nexty]=Truecount +=1return countfor i in range(m):for j in range(n):if not visited[i][j] and grid[i][j]==1:count = bfs(i,j)maxres = max(maxres,count)return maxres

二、DFS

class Solution(object):def maxAreaOfIsland(self, grid):""":type grid: List[List[int]]:rtype: int"""# DFSm,n = len(grid),len(grid[0])visited = [[False]*n for _ in range(m)]dirs = [(-1,0),(0,1),(1,0),(0,-1)]result = 0def dfs(x,y):count = 1for d in dirs:nextx = x+d[0]nexty = y+d[1]if nextx>=m or nextx<0 or nexty>=n or nexty<0:continueif visited[nextx][nexty] or grid[nextx][nexty]==0:continuevisited[nextx][nexty]=Trueres = dfs(nextx,nexty)count += resreturn countfor i in range(m):for j in range(n):if not visited[i][j] and grid[i][j]==1:visited[i][j]=Truecount = dfs(i,j)result = max(result,count)return result

1020.飞地的数量

题目链接

一、DFS

class Solution(object):def numEnclaves(self, grid):m, n = len(grid), len(grid[0])visited = [[False] * n for _ in range(m)]dirs = [(-1, 0), (0, 1), (1, 0), (0, -1)]def dfs(x, y):visited[x][y] = True# grid[x][y] = 2  # Mark as visited by changing the value to 2for d in dirs:nextx, nexty = x + d[0], y + d[1]if 0 <= nextx < m and 0 <= nexty < n and not visited[nextx][nexty] and grid[nextx][nexty] == 1:dfs(nextx, nexty)for i in range(m):for j in [0, n-1]:  # Only left and right bordersif grid[i][j] == 1 and not visited[i][j]:dfs(i, j)for j in range(n):for i in [0, m-1]:  # Only top and bottom bordersif grid[i][j] == 1 and not visited[i][j]:dfs(i, j)# Count cells that are still 1 (enclaves)res = 0for i in range(m):for j in range(n):if grid[i][j] == 1 and not visited[i][j]:res += 1return res

二、BFS

class Solution(object):def numEnclaves(self, grid):m, n = len(grid), len(grid[0])visited = [[False] * n for _ in range(m)]dirs = [(-1, 0), (0, 1), (1, 0), (0, -1)]# BFSdef bfs(x,y):q = collections.deque()q.append((x,y))while q:x,y = q.popleft()for d in dirs:nextx = x+d[0]nexty = y+d[1]if 0<= nextx <m and 0<=nexty<n and visited[nextx][nexty]==False and grid[nextx][nexty]==1:q.append((nextx,nexty))visited[nextx][nexty]=Truefor i in range(m):for j in [0,n-1]:if visited[i][j]==False and grid[i][j]==1:visited[i][j]=Truebfs(i,j)for j in range(n):for i in [0,m-1]:if visited[i][j]==False and grid[i][j]==1:visited[i][j]=Truebfs(i,j)# Count cells that are still 1 (enclaves)res = 0for i in range(m):for j in range(n):if grid[i][j] == 1 and not visited[i][j]:res += 1return res

三、本题总结

其实就是从边缘遍历,不是整幅图遍历,最后边缘能遍历到的就都visited=True了,剩下的False且为陆地的就是飞地。


130.被围绕的区域

题目链接

一、DFS

class Solution(object):def solve(self, board):""":type board: List[List[str]]:rtype: None Do not return anything, modify board in-place instead."""# DFSm, n = len(board), len(board[0])dirs = [(-1, 0), (0, 1), (1, 0), (0, -1)]# DFSdef dfs(x, y):board[x][y] = 'A'  # Mark as visited by changing the value to 2for d in dirs:nextx, nexty = x + d[0], y + d[1]if 0 <= nextx < m and 0 <= nexty < n  and board[nextx][nexty] == 'O':dfs(nextx, nexty)for i in range(m):for j in [0, n-1]:  # Only left and right bordersif board[i][j] == 'O' :dfs(i, j)for j in range(n):for i in [0, m-1]:  # Only top and bottom bordersif board[i][j] == 'O' :dfs(i, j)for i in range(m):for j in range(n):if board[i][j] == 'O' :board[i][j]='X'if board[i][j]=='A':board[i][j]='O'return board

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/872040.shtml

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

相关文章

自动化(二正)

Java接口自动化用到的技术栈 技术栈汇总&#xff1a; ①Java基础&#xff08;封装、反射、泛型、jdbc&#xff09; ②配置文件解析(properties) ③httpclient&#xff08;发送http请求&#xff09; ④fastjson、jsonpath处理数据的 ⑤testng自动化测试框架重点 ⑥allure测试报…

JMeter CSV 参数文件的使用教程

在 JMeter 测试过程中&#xff0c;合理地使用参数化技术是提高测试逼真度的关键步骤。本文将介绍如何通过 CSV 文件实现 JMeter 中的参数化。 设定 CSV 文件 首先&#xff0c;构建一个包含需要参数化数据的 CSV 文件。打开任何文本编辑器&#xff0c;输入希望模拟的用户数据&…

Scrapy 核心组件之Spiders组件的使用

Spiders 组件是 Scrapy 框架的核心组件&#xff0c;它定义了网络爬虫抓取网站数据的方式&#xff0c;其中包 括抓取的动作&#xff0c;如是否跟进链接&#xff0c;以及如何从网页内容中提取结构化数据。换言之&#xff0c;Spiders 组件用于定义抓取网页数据的动作及解析网页数据…

IGBT参数学习

IGBT&#xff08;绝缘栅双极晶体管(Insulated Gate Bipolar Transistor)&#xff09;的内部架构如下所示&#xff1a; IGBT是个单向的器件&#xff0c;电流只能朝一个方向流动&#xff0c;通常IGBT会并联一个续流二极管 IGBT型号&#xff1a;IKW40N120T2 IKW40N120T2 电路符号…

ICPC铜牌算法

铜牌算法 2021ICPC上海站 铜牌开题: D:数学思维构造 E:贪心思维 G:树形dp H:图论克鲁斯卡尔重构树 I:背包dp K:思维构造2021ICPC沈阳站 铜牌开题: B:并查集 E:字符串简单查找 F:字符串简单构造模拟 J:BFS预处理2021ICPC南京站 铜牌开题: A:思维 C:暴力均摊stl D:贪心暴力…

【代码规范】.train(False)和.eval()的相似性和区别

【代码规范】.train(False)和.eval()的相似性和区别 文章目录 一、.train(False) 和 .eval() 的功能二、.train(False) 和 .eval() 的区别2.1 .eval()2.2 .train(False)2.3 总结 三、.eval()更加规范 一、.train(False) 和 .eval() 的功能 .train(False) 和 .eval() 在功能上非…

Centos7 安装Redis6.2.6 gcc报错问题解决

Redis 报错信息 make: *** [all] 错误 2 安装gcc 修改yum源,在安装更新rpm包时获得比较理想的速度&#xff0c;走阿里云镜像通道 发现报错信息如下: 正在解析主机 mirrors.aliyun.com (mirrors.aliyun.com)… 失败&#xff1a;未知的名称或服务。 wget: 无法解析主机地址 “mi…

LLM:学习清单 ing

根据模型的数据流程方向和自己的经验列出&#xff1a; 一、模型输入 分词器&#xff1a;BPE&#xff0c;BBPE 位置编码&#xff1a;绝对位置编码&#xff0c;三角函数编码&#xff0c;ROPE 词向量模型&#xff1a;词袋&#xff0c;监督学习模型&#xff1b;BGE&#xff0c;BC…

数据中心内存RAS技术发展背景

随着数据量的爆炸性增长和云计算的普及&#xff0c;数据中心内存的多比特错误及由无法纠正错误(UE)导致的停机问题日益凸显&#xff0c;这些故障不仅影响服务质量&#xff0c;还会带来高昂的修复或更换成本。随着工作负载、硬件密度以及对高性能要求的增加&#xff0c;数据中心…

01--IptablesFirewalld详解

前言&#xff1a;这里写一下&#xff0c;前面文章里都是直接关闭然后实验&#xff0c;感觉这样有点草率&#xff0c;这里写一下大概的概念和用法&#xff0c;作为知识的补充&#xff0c;这章写轻松点&#xff0c;毕竟是网安毕业的&#xff0c;算是给自己放松一下吧。 1、iptabl…

RK3568笔记三十八:DS18B20驱动开发测试

若该文为原创文章&#xff0c;转载请注明原文出处。 DS18B20驱动参考的是讯为电子的单总线驱动第十四期 | 单总线_北京迅为的博客-CSDN博客 博客很详细&#xff0c;具体不描述。 只是记录测试下DS18B20读取温度。 一、介绍 流程基本和按键驱动差不多&#xff0c;主要功能是…

asio之fd_set_adapter

简介 fd_set_adapter是对fd_set的封装 fd_set_adapter 是不同平台fd_set的别名 #if defined(BOOST_ASIO_WINDOWS) || defined(__CYGWIN__) typedef win_fd_set_adapter fd_set_adapter; #else typedef posix_fd_set_adapter fd_set_adapter; #endifposix_fd_set_adapter l…

为什么要做USB转多路UART项目 - 技术角度

前言 之前专门为USB转多路UART项目写了个序&#xff0c;提到了技术方案原因&#xff0c;这个文章打算展开讲一下。 一、工业物联网关 最初是因为有个工业物联网关的项目&#xff0c;需要出多路RS485接口&#xff0c;每路外接几十个三相电表PLC之类的电力电子设备。其中一款需…

构建艺术:精通Gradle依赖替换的策略与实践

构建艺术&#xff1a;精通Gradle依赖替换的策略与实践 在软件开发的构建过程中&#xff0c;依赖管理是确保项目顺利进行的关键环节。Gradle&#xff0c;作为一款强大的构建工具&#xff0c;提供了灵活的依赖管理功能&#xff0c;包括依赖替换&#xff0c;这使得开发者能够精细…

【论文极速读】 可微分检索索引(Differential Search Index, DSI)

【论文极速读】 可微分检索索引&#xff08;Differential Search Index&#xff0c; DSI&#xff09; FesianXu 20240714 at WeChat Search Team 前言 最近从朋友处得知了DSI这个概念&#xff0c;所谓的可微分检索索引DSI&#xff0c;就是通过语言模型将检索过程中的索引和召回…

​低学历的的程序员如何逆袭?​

​低学历的的程序员如何逆袭?​ 我在领英上看到一篇文章《低学历者逆袭成功的概率是多少》,该文章将低学历与不读书化等号。 事实上低学历与是否读书并无半点关系,这跟在寺庙里念经还是在家修行一个道理。另外知识的获取已经不仅仅限于读书一种,你可以从多种渠道获得知识…

pixelRNN与pixelCNN

目的&#xff1a;为了找到一个最能解释得到的生成样本的模型 PixelRNN 我们需要利用概率链式法则将图像x的生成概率转变为每个像素生成概率的乘积&#xff0c;也就是每个通道生成概率的乘积。 公式&#xff1a; 公式解释&#xff1a;p(x)是每个图像x的概率&#xff1b;右侧为…

浅聊授权-spring security和oauth2

文章目录 前言自定义授权spring security授权oauth2授权概述 前言 通常说到授权&#xff0c;就会想到登录授权、token令牌、JWT等概念&#xff0c;授权。顾名思义就是服务器授予了客户端访问资源的权益&#xff0c;那么要实现授权有几种方案呢&#xff0c;三种授权方式在公司项…

c++dll库的制作和使用

01、dll库的创建使用 创建dll项目 dllexport到处 dllimport导入 分别制定dll和lib的生成目录 调用&#xff1a; 包含头文件 常规添加 最后把dll文件拷贝到程序 成功调用

使用Keepalived实现双机热备(虚拟漂移IP地址)详细介绍

&#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f427;Linux基础知识(初学)&#xff1a;点击&#xff01; &#x1f427;Linux高级管理防护和群集专栏&#xff1a;点击&#xff01; &#x1f510;Linux中firewalld防火墙&#xff1a;点击&#xff01; ⏰️创作…