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

FloodFill算法——搜索算法

一、什么是FloodFill算法

FloodFill算法字面意思就是洪水灌溉法,比如我们有这么一块地:

        0表示平原,正数表示高地,负数表示凹地,那么当洪水来临时这些凹地会被优先灌满。而我们要找的正是这些联通块,如: 

 

        它是一种暴力搜索的思想,只要我们把每个地方都搜索一遍,那么最终的结果必定会水落石出。 通常可以使用BFS、DFS或并查集解决。

BFS(广度优先搜索)——搜索算法_广度优先搜索bfs-CSDN博客

DFS+回溯+剪枝(深度优先搜索)——搜索算法-CSDN博客

接下来我们直接从题中感受。

二、试题一:岛屿数量

        我们可以使用两层for循环找到没有搜索过的“1”然后在从这个“1”开始进行BFS或DFS展开,在期间使用哈希表记录每个“1”是否已经搜索过。每一次新的展开之前做一下计数,最后得到最终答案。

BFS代码示例:

class Solution {
public:int n=0,m=0,ret=0;int dx[4]={0,0,-1,1},dy[4]={-1,1,0,0};int numIslands(vector<vector<char>>& grid){n=grid.size(),m=grid[0].size(); vector<vector<bool>> hash(n,vector<bool>(m));for(int i=0;i<n;i++)for(int j=0;j<m;j++)if(grid[i][j]=='1'&&!hash[i][j]) bfs(i,j,grid,hash);  return ret;}void bfs(int i,int j,vector<vector<char>>& grid,vector<vector<bool>>& hash){ret++;queue<pair<int,int>> q;hash[i][j]=true;q.push({i,j});while(!q.empty()){auto [a,b] = q.front();q.pop();for(int k=0;k<4;k++){int x=a+dx[k],y=b+dy[k];if(x>=0&&x<n&&y>=0&&y<m&&grid[x][y]=='1'&&!hash[x][y]){q.push({x,y});hash[x][y]=true;}}}}
};

 DFS代码示例:

class Solution {
public:int n=0,m=0,ret=0;int dx[4]={0,0,-1,1},dy[4]={-1,1,0,0};int numIslands(vector<vector<char>>& grid){n=grid.size(),m=grid[0].size();vector<vector<bool>> hash(n,vector<bool>(m));for(int i=0;i<n;i++)for(int j=0;j<m;j++)if(grid[i][j]=='1'&&!hash[i][j]){ret++;dfs(i,j,grid,hash);}return ret;}void dfs(int i,int j,vector<vector<char>>& grid,vector<vector<bool>>& hash){hash[i][j]=true;for(int k=0;k<4;k++){int x=i+dx[k],y=j+dy[k];if(x>=0&&x<n&&y>=0&&y<m&&grid[x][y]=='1'&&!hash[x][y])dfs(x,y,grid,hash);}}
};

三、试题二:太平洋大西洋水流问题 

        按题意,如果一个数能够与上边界和左边界元素联通,那么它就能流入“太平洋”,如果与右边界或下边界元素联通则流入“大西洋” 。

        如果我们一个元素一个元素的去搜索,去看它流入“太平洋”,还是“大西洋”,那么效率势必会很低。我们可以直接从边界扩展,能被上边界和左边界扩展到的是“太平洋”,能被下边界和右边界扩展到的是“大西洋”。所以需要使用一个哈希表记录两个状态(“大西洋,“太平洋”),可以使用一个pair<bool,bool>作为哈希表的元素类型。

DFS代码示例: 

class Solution {
public:vector<vector<pair<bool,bool>>> hash;int n=0,m=0;vector<vector<int>> pacificAtlantic(vector<vector<int>>& heights){n=heights.size(),m=heights[0].size();hash.resize(n);for(int i=0;i<n;i++) hash[i].resize(m,{false,false});for(int j=0;j<m;j++) dfs(0,j,heights,1),dfs(n-1,j,heights,2);for(int i=0;i<n;i++) dfs(i,0,heights,1),dfs(i,m-1,heights,2);vector<vector<int>> ret;for(int i=0;i<n;i++)for(int j=0;j<m;j++)if(hash[i][j].first&&hash[i][j].second) ret.push_back({i,j});return ret;}int dx[4]={0,0,1,-1},dy[4]={-1,1,0,0};void dfs(int i,int j,vector<vector<int>>& heights,int f){f==1?hash[i][j].first=true:hash[i][j].second=true;for(int k=0;k<4;k++){int x=dx[k]+i,y=dy[k]+j;if(x>=0&&x<n&&y>=0&&y<m&&heights[i][j]<=heights[x][y]){if(f==1&&hash[x][y].first) continue;if(f==2&&hash[x][y].second) continue;dfs(x,y,heights,f);}}}
};

BFS代码示例:

class Solution {
public:vector<vector<pair<bool,bool>>> hash;int n=0,m=0;vector<vector<int>> pacificAtlantic(vector<vector<int>>& heights){n=heights.size(),m=heights[0].size();hash.resize(n);for(int i=0;i<n;i++) hash[i].resize(m,{false,false});for(int j=0;j<m;j++) bfs(0,j,heights,1),bfs(n-1,j,heights,2);for(int i=0;i<n;i++) bfs(i,0,heights,1),bfs(i,m-1,heights,2);vector<vector<int>> ret;for(int i=0;i<n;i++)for(int j=0;j<m;j++)if(hash[i][j].first&&hash[i][j].second) ret.push_back({i,j});return ret;}int dx[4]={0,0,1,-1},dy[4]={-1,1,0,0};void bfs(int i,int j,vector<vector<int>>& heights,int f){f==1?hash[i][j].first=true:hash[i][j].second=true;queue<pair<int,int>> q;q.push({i,j});while(!q.empty()){auto [a,b] = q.front();q.pop();for(int k=0;k<4;k++){int x=a+dx[k],y=b+dy[k];if(x>=0&&x<n&&y>=0&&y<m&&heights[a][b]<=heights[x][y]){if(f==1&&hash[x][y].first) continue;if(f==2&&hash[x][y].second) continue;f==1?hash[x][y].first=true:hash[x][y].second=true;q.push({x,y});}}}}
};

相关文章:

FloodFill算法——搜索算法

一、什么是FloodFill算法 FloodFill算法字面意思就是洪水灌溉法&#xff0c;比如我们有这么一块地&#xff1a; 0表示平原&#xff0c;正数表示高地&#xff0c;负数表示凹地&#xff0c;那么当洪水来临时这些凹地会被优先灌满。而我们要找的正是这些联通块&#xff0c;如&…...

H5接入支付宝手机网站支付并实现

小程序文档 - 支付宝文档中心 1.登录 支付宝开放平台 创建 网页/移动应用 2.填写创建应用信息 3.配置开发设置 4.网页/移动应用&#xff1a;需要手动上线。提交审核后&#xff0c;预计 1 个工作日的审核时间。详细步骤可点击查看 上线应用 。应用上线后&#xff0c;还需要完成…...

基于SpringBoot+uniapp的在线办公小程序+LW示例参考

1.项目介绍 系统角色&#xff1a;管理员、普通用户功能模块&#xff1a;员工管理、部门信息管理、职位信息管理、会议记录、待办事项、工资信息、留言板等技术选型&#xff1a;SpringBoot&#xff0c;Vue&#xff08;后端管理web&#xff09;&#xff0c;uniapp等测试环境&…...

文章精读篇——OMG-LLaVA

题目&#xff1a;OMG-LLaVA: Bridging Image-level, Object-level, Pixel-level Reasoning and Understanding 会议&#xff1a;Conference on Neural Information Processing Systems 2024 论文&#xff1a;http://arxiv.org/abs/2406.19389 主页&#xff1a;https://lxtgh…...

两个同一对象targetList和 sourceList 去重

我现在需要解决的问题是从一个Java的源列表`sourceList`中移除所有在目标列表`targetList`中存在的数据,并且还要去除`targetList`中的重复数据。让我先理清楚这两个问题的思路。 首先,如何快速从`sourceList`中移除含有`targetList`的数据。这里的“含有”应该是指两个列表中…...

软件开发 | GitHub企业版常见问题解读

什么是GitHub企业版&#xff1f; GitHub企业版是一个企业级软件开发平台&#xff0c;专为现代化开发的复杂工作流程而设计。 作为可扩展的平台解决方案&#xff0c;GitHub企业版使组织能够无缝集成其他工具和功能&#xff0c;并根据特定需求定制开发环境&#xff0c;提高整体…...

Docker 网络的配置与管理

目录 查看所有网络 查看网络详细信息 创建新的网络 删除网络 清理未使用的网络 将容器连接到网络 将容器从网络中断开 将容器端口映射到宿主机 绑定到特定 IP 地址 为容器设置自定义 DNS 查看所有网络 docker network ls 功能&#xff1a;列出所有 Docker 网络。 工…...

新手自学:如何用gromacs对简单分子复合物进行伞形采样

1、建立体系: 1、将蛋白的pdb文件转化为gmx: gmx pdb2gmx -f 2BEG_model1_capped.pdb -ignh -ter -o complex.gro 这个网页可以实现将多肽序列转化为pdb: ProBuilder On-line 这个教程的蛋白2BFG包含两条链(chain A和B) 在生成的topol文件中,增加如下的内容,效果就…...

力扣第一题 哈希解法 O(n)时间复杂度

题目&#xff1a; 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那俩个整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案&#xff0c;并且你不能使用两次相同的元素。 你可以按任意顺序返…...

elementui: el-dialog的header设置样式不生效

问&#xff1a; el-dialog的header设置样式不生效 回答&#xff1a; 场景&#xff1a; <el-dialogv-model"dialogVisible"width"800px":before-close"beforeClose"append-to-body:close-on-click-modal"false"title"增加文…...

libpcap 的使用

1.libpcap的模式 有线环境: 使用混杂模式promisous&#xff0c;完成监听无线环境: 使用监听模式monitor&#xff0c;完成监听 2.交叉编译libpcap 设置好交叉编译工具链后下载libpcap源码使用configure进行构建&#xff1a;–disable-shared 构建静态库&#xff0c;–host 、…...

ArcGISPro AA表O_Name字段 内容 复制到BB表BB字段里

import arcpy# 设置工作空间和要处理的表路径 resource_shape_table r"AA表.shp" # 源表路径 resource_assets_table r"BB表.shp" # 目标表路径# 使用 SearchCursor 读取源表中的 O_Name 字段 with arcpy.da.SearchCursor(resource_shape_table, [O_Na…...

2.5 使用注解进行单元测试详解

Mockito 使用注解进行单元测试详解 Mockito 提供了一系列注解来简化测试代码的编写&#xff0c;减少手动创建和管理 Mock 对象的样板代码。结合 JUnit 5&#xff0c;可以更高效地构建清晰、易维护的单元测试。 1. 核心注解概览 注解作用Mock创建并注入一个 Mock 对象&#xf…...

当没有OpenGL时,Skia如何绘制?

Skia 是可以在没有 OpenGL 的情况下进行图形绘制的&#xff0c;但是具体能否成功绘制图形&#xff0c;取决于 Skia 是如何配置的&#xff0c;以及平台上是否提供了其他的底层图形 API。 Skia 的底层依赖 Skia 的目标是提供一种跨平台的 2D 图形绘制接口。为了加速图形渲染&…...

SaaS+AI应用架构:业务场景、智能体、大模型、知识库、传统工具系统

SaaSAI应用架构&#xff1a;业务场景、智能体、大模型、知识库、传统工具系统 大家好&#xff0c;我是汤师爷~ 在SaaS与AI应用的演进过程中&#xff0c;合理的架构设计至关重要。本节将详细介绍其五个核心层次&#xff1a; 业务场景层&#xff1a;发现和确定业务场景智能体层…...

Go 语言中如何高效地处理集合

文章精选推荐 1 JetBrains Ai assistant 编程工具让你的工作效率翻倍 2 Extra Icons&#xff1a;JetBrains IDE的图标增强神器 3 IDEA插件推荐-SequenceDiagram&#xff0c;自动生成时序图 4 BashSupport Pro 这个ides插件主要是用来干嘛的 &#xff1f; 5 IDEA必装的插件&…...

布隆过滤器到底是什么东西?它有什么用

布隆过滤器&#xff1a;用概率换空间的奇妙数据结构 引言&#xff1a;当空间成为奢侈品 在互联网每天产生2.5万亿字节数据的时代&#xff0c;Google每秒处理超过9万次搜索请求&#xff0c;Redis缓存系统支撑着百万级QPS的访问。面对如此海量的数据处理需求&#xff0c;传统的…...

【数据结构初阶第十节】队列(详解+附源码)

好久不见。。。别不开心了&#xff0c;听听喜欢的歌吧 必须有为成功付出代价的决心&#xff0c;然后想办法付出这个代价。云边有个稻草人-CSDN博客 目录 一、概念和结构 二、队列的实现 Queue.h Queue.c test.c Relaxing Time&#xff01; ————————————《有没…...

沪深300股指期权能对股指期货进行完全套保吗?

锦鲤三三每日分享期权知识&#xff0c;帮助期权新手及时有效地掌握即市趋势与新资讯&#xff01; 沪深300股指期权能对股指期货进行完全套保吗&#xff1f; 沪深300股指期权是以沪深300指数为标的物的期权&#xff0c;而沪深300股指期货则是以该指数作为标的的期货合约。 理…...

JAVA学习第三天

继承关系变量访问的特点 01.方法中找 02.子类变量定义中找 03.父类中找 this和super关键字的使用区别&#xff1a; super父类构造函数的使用&#xff1a; 使用子类构造函数时&#xff0c;都会初始化父类的数据&#xff0c;自动调用父类的无参构造函数 super内存图——007 继…...

观测多模型API调用延迟与稳定性选择合适服务商

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 观测多模型API调用延迟与稳定性选择合适服务商 在实际项目开发中&#xff0c;直接依赖单一模型服务商可能会面临服务波动或响应延迟…...

Mac Mouse Fix终极指南:如何让普通鼠标在Mac上获得超越触控板的体验

Mac Mouse Fix终极指南&#xff1a;如何让普通鼠标在Mac上获得超越触控板的体验 【免费下载链接】mac-mouse-fix Mac Mouse Fix - Make Your $10 Mouse Better Than an Apple Trackpad! 项目地址: https://gitcode.com/GitHub_Trending/ma/mac-mouse-fix 还在为Mac上第三…...

Midjourney Basic计划真实体验:7天高强度测试+37组对比图,揭示隐藏限制与生产力断层

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Midjourney Basic计划真实体验&#xff1a;7天高强度测试37组对比图&#xff0c;揭示隐藏限制与生产力断层 过去一周&#xff0c;我以全职创作者身份深度使用 Midjourney Basic 计划&#xff08;$10/月…...

MATLAB roots函数实战:5分钟搞定高阶系统稳定性判断(附完整代码)

MATLAB roots函数实战&#xff1a;高阶系统稳定性分析的黄金法则 在控制工程和自动化领域&#xff0c;系统稳定性分析是每个工程师的必修课。面对复杂的高阶系统特征方程&#xff0c;传统的手工计算方法不仅耗时耗力&#xff0c;还容易出错。而MATLAB的roots函数配合简单的可视…...

Claude Orchestra:基于Claude模型的AI智能体编排框架实战指南

1. 项目概述&#xff1a;Claude Orchestra 是什么&#xff0c;以及它为何值得关注最近在探索如何将大型语言模型&#xff08;LLM&#xff09;的能力更系统地整合到工作流中时&#xff0c;我遇到了一个名为mianham9042/claude-orchestra的项目。这个名字本身就很有意思——“Cla…...

告别内存焦虑!STM32H743全系列SRAM(ITCM/DTCM/AXI)实战分配指南(MDK/IAR双环境)

STM32H743内存优化实战&#xff1a;从理论到精准分配的完整指南 在嵌入式系统开发中&#xff0c;内存管理往往是决定项目成败的关键因素之一。STM32H743作为STMicroelectronics推出的高性能微控制器系列&#xff0c;其复杂的内存架构既带来了性能优势&#xff0c;也增加了开发难…...

【20年架构老兵亲授】:SITS 2026服务边界定义三原则、8类AI上下文耦合陷阱及动态治理沙盒实测数据

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;AI原生微服务架构&#xff1a;SITS 2026服务拆分与治理策略 AI原生微服务并非传统微服务的简单升级&#xff0c;而是以模型生命周期、推理上下文感知和实时反馈闭环为驱动的服务边界重构。SITS 2026&am…...

不只是抓包:巧用Drony为Android APP设置“专属网络通道”,测试本地Mock服务

巧用Drony构建Android应用专属调试通道&#xff1a;从Mock服务到精准流量控制 在移动应用开发与测试过程中&#xff0c;前后端分离架构已成为主流范式。然而&#xff0c;当Android应用硬编码了生产环境API地址或缺乏灵活的配置机制时&#xff0c;如何在不修改代码的情况下将特定…...

手把手教你用C8051F330自制BLheli电调:从测绘XP-12A到暴力测试70涵道

从零构建BLheli电调&#xff1a;C8051F330硬件逆向与70涵道暴力测试全指南 当你拆开一台现成的航模电调&#xff0c;看到里面密密麻麻的元件时&#xff0c;是否想过自己也能从头打造一个&#xff1f;本文将带你深入电调硬件设计的核心&#xff0c;从测绘商业电调XP-12A开始&…...

汽车电喷系统间歇性启动故障诊断:从信号缺失到精准修复

1. 故障现象与初步排查&#xff1a;一个“不合常理”的启动问题我父亲打电话来&#xff0c;说他的皮卡又启动不了了&#xff0c;得“灌点油”才能着车。我一听就觉得不对劲&#xff0c;这车是电喷的&#xff0c;又不是化油器老古董&#xff0c;哪有用汽油“灌喉”来启动的道理&…...