初识 Floodfall 算法
文章目录
- **一、Floodfall 算法的概述**
- **二、深度优先搜索(DFS)和广度优先搜索(BFS)在 Floodfall 算法中的应用**
- **三、算法的基本原理**
- **四、应用场景**
一、Floodfall 算法的概述
Floodfall 算法通常用于解决与区域填充、图的遍历等相关的问题。它的中文名字:洪水灌溉,顾名思义它的核心思想是从一个起始点开始,像洪水一样蔓延,直到满足特定的条件或覆盖整个目标区域。
Floodfall 算法在实现过程中,常常会基于深度优先搜索(DFS)和广度优先搜索(BFS)的思想。
二、深度优先搜索(DFS)和广度优先搜索(BFS)在 Floodfall 算法中的应用
深度优先搜索(DFS)在 Floodfall 算法中,会沿着一条路径尽可能深地探索下去,直到无法继续,然后回溯。这种方式在某些情况下能够快速找到较深的区域,但可能会忽略一些较近但隐藏较深的区域。
例如,在一个迷宫中,如果使用 DFS 进行 Floodfall 式的探索,可能会先深入一条复杂的长通道,而错过一些就在入口附近但需要绕一点路才能到达的区域。
广度优先搜索(BFS)则是逐层地向外扩展,先访问距离起始点近的节点,再逐步扩展到更远的节点。在 Floodfall 算法中,BFS 能确保先填充距离起始点较近的区域,填充的顺序更加有序和可预测。
比如在地图填充中,使用 BFS 进行 Floodfall 操作,会先填充起始点周围的区域,再逐渐向外扩散。
三、算法的基本原理
Floodfall 算法一般会使用某种数据结构(如队列或栈)来存储待处理的节点。从起始节点出发,将其相邻的未访问节点加入数据结构,然后依次处理这些节点,不断扩展填充区域。
四、应用场景
- 图像处理中的颜色填充。
- 游戏地图中的区域探索。
下面是一个使用 C++实现的简单 Floodfall 算法示例代码,用于填充二维矩阵中的一个区域,分别展示了基于 DFS 和 BFS 的实现方式:
#include <iostream>
#include <stack>
#include <queue>// 定义矩阵的大小
const int ROWS = 10;
const int COLS = 10;// 方向数组,用于遍历相邻节点
const int dx[] = { -1, 1, 0, 0 };
const int dy[] = { 0, 0, -1, 1 };// 定义一个结构体来表示节点
struct Node {int x;int y;
};// 基于 DFS 的 FloodFill 函数
void floodFillDFS(int grid[ROWS][COLS], int startX, int startY, int targetColor, int newColor) {std::stack<Node> s;Node start;start.x = startX;start.y = startY;s.push(start);while (!s.empty()) {Node curr = s.top();s.pop();int x = curr.x;int y = curr.y;// 如果当前节点的颜色与目标颜色不同,跳过if (grid[x][y]!= targetColor) {continue;}// 更改颜色grid[x][y] = newColor;// 遍历相邻节点for (int i = 0; i < 4; i++) {int newX = x + dx[i];int newY = y + dy[i];// 检查边界if (newX >= 0 && newX < ROWS && newY >= 0 && newY < COLS) {Node next;next.x = newX;next.y = newY;s.push(next);}}}
}// 基于 BFS 的 FloodFill 函数
void floodFillBFS(int grid[ROWS][COLS], int startX, int startY, int targetColor, int newColor) {std::queue<Node> q;Node start;start.x = startX;start.y = startY;q.push(start);while (!q.empty()) {Node curr = q.front();q.pop();int x = curr.x;int y = curr.y;// 如果当前节点的颜色与目标颜色不同,跳过if (grid[x][y]!= targetColor) {continue;}// 更改颜色grid[x][y] = newColor;// 遍历相邻节点for (int i = 0; i < 4; i++) {int newX = x + dx[i];int newY = y + dy[i];// 检查边界if (newX >= 0 && newX < ROWS && newY >= 0 && newY < COLS) {Node next;next.x = newX;next.y = newY;q.push(next);}}}
}// 打印矩阵
void printGrid(int grid[ROWS][COLS]) {for (int i = 0; i < ROWS; i++) {for (int j = 0; j < COLS; j++) {std::cout << grid[i][j] << " ";}std::cout << std::endl;}
}int main() {int grid[ROWS][COLS] = {{0, 0, 0, 0, 0, 0, 0, 0, 0, 0},{0, 1, 1, 1, 1, 1, 1, 1, 1, 0},{0, 1, 0, 0, 0, 0, 0, 0, 1, 0},{0, 1, 0, 1, 1, 1, 1, 0, 1, 0},{0, 1, 0, 1, 0, 0, 1, 0, 1, 0},{0, 1, 0, 1, 0, 0, 1, 0, 1, 0},{0, 1, 0, 1, 1, 1, 1, 0, 1, 0},{0, 1, 0, 0, 0, 0, 0, 0, 1, 0},{0, 1, 1, 1, 1, 1, 1, 1, 1, 0},{0, 0, 0, 0, 0, 0, 0, 0, 0, 0}};std::cout << "原始矩阵:" << std::endl;printGrid(grid);std::cout << "基于 DFS 填充后的矩阵:" << std::endl;floodFillDFS(grid, 1, 1, 1, 2);printGrid(grid);std::cout << "基于 BFS 填充后的矩阵:" << std::endl;floodFillBFS(grid, 1, 1, 2, 3);printGrid(grid);return 0;
}
在上述代码中,我们分别实现了基于 DFS 和 BFS 的 Floodfall 算法,用于填充二维矩阵中的指定区域。
相关文章:
初识 Floodfall 算法
文章目录 **一、Floodfall 算法的概述****二、深度优先搜索(DFS)和广度优先搜索(BFS)在 Floodfall 算法中的应用****三、算法的基本原理****四、应用场景** 一、Floodfall 算法的概述 Floodfall 算法通常用于解决与区域填充、图的…...
[Linux] LVM挂载的硬盘重启就掉的问题解决
问题:系统重启后挂在逻辑卷的盘会掉(必现) 环境:SUSE Linux 11 SP4 原因:boot.lvm是关闭的 解决:boot.lvm设置开启 参考资料: linux下lvm状态Not avaliable问题排查及处理(常见Suse操作系统…...
YOLOv8改进 | 主干网络 | 用EfficientNet卷积替换backbone【教程+代码 】
秋招面试专栏推荐 :深度学习算法工程师面试问题总结【百面算法工程师】——点击即可跳转 💡💡💡本专栏所有程序均经过测试,可成功执行💡💡💡 专栏目录 :《YOLOv8改进有效涨点》专栏介绍 & 专栏目录 | 目前已有80+篇内容,内含各种Head检测头、损失函数Loss、…...
数据库规范化设计 5大基本原则
规范化设计原则是数据库设计的基本原则,有助于减少数据冗余,提高数据一致性和完整性,简化数据管理,增强数据安全性,对整个开发项目至关重要。而缺乏规范化设计会导致数据冗余,增加存储成本,引发…...
【nginx】解决k8s中部署nginx转发不会自动更新域名解析启动失败的问题
文章目录 1. 问题2.解决办法3.扩展说明3.1 DNS解析阶段划分3.2 问题说明3.2.1 先看/etc/resolv.conf说明3.2.2 针对第一个问题3.2.3 针对第二个问题 【后端】NginxluaOpenResty高性能实践 参考: https://blog.csdn.net/u010837612/article/details/123275026 1. 问…...
LeetCode637 二叉树的层平均值
前言 题目: 637. 二叉树的层平均值 文档: 代码随想录——二叉树的层平均值 编程语言: C 解题状态: 求取平均值的时候出现了点问题 思路 C中,浮点数的相加会产生精度误差,求取平均值时最好只在最后一步进行…...
王学岗ASM
服务发现 package com.example.testasm;import android.content.Context; import android.os.Bundle;import androidx.activity.EdgeToEdge; import androidx.appcompat.app.AppCompatActivity; import androidx.core.graphics.Insets; import androidx.core.view.ViewCompat;…...
【数据结构】—— 队列
1、队列的概念2、队列的结构如何选择合适的数据结构实现队列(数组or链表) 3、队列的链式存储3.1 队列的链式存储结构3.2 队列的常见接口3.3 队列的接口实现初始化判空入队列出队列获取队头元素获取队尾元素获取节点个数销毁 3.4 源代码 4、队列的顺序存储…...
vue中openlayers过滤高亮显示某个图层
vue中openlayers过滤高亮显示某个图层 openlayers库没有直接支持这样设置,所以可以使用库:ol-ext,地址:https://viglino.github.io/ol-ext/examples/filter/map.filter.crop.html 效果: 关键代码: /**…...
WPF篇(11)-ToolTip控件(提示工具)+Popup弹出窗口
ToolTip控件 ToolTip控件继承于ContentControl,它不能有逻辑或视觉父级,意思是说它不能以控件的形式实例化,它必须依附于某个控件。因为它的功能被设计成提示信息,当鼠标移动到某个控件上方时,悬停一会儿,…...
【mysql 第一篇章】系统和数据库的交互方法
一、宏观的查看系统怎么和数据库交互 在我们刚刚接触系统和数据库的时候不明白其中的原理,只知道系统和数据库是需要交互的。所以我们会理解成上图的形式。 二、MYSQL 驱动 随着我们的学习时间的加长以及对程序的了解,发现链接数据库是需要有别的工具辅…...
数据结构-位运算总结
位运算总结: 1.求位1的个数 191. 位1的个数 - 力扣(LeetCode) 有两种写法: 1.是把该数不断的去与0x1相与,得到该数的最后一位的值,然后判断他是不是1,再把该数更新一下整体往后移动一位也就…...
java 异常堆栈的由来
编写的程序代码内部错误产生的异常,如调用对象为空(空指针异常)、数组越界异常、除0异常等。这种通常称为未检查的异常(Runtime异常子类),在虚拟机中执行时会集中处理这些异常。其他运行中异常,通过throw语句主动抛出的…...
【推荐系统】【多任务学习】Progressive Layered Extraction (PLE)
Progressive Layered Extraction (PLE): A Novel Multi-Task Learning (MTL) Model for Personalized Recommendations 文章目录 Progressive Layered Extraction (PLE): A Novel Multi-Task Learning (MTL) Model for Personalized Recommendations1 论文出处2 背景2.1 背景介…...
java -转win32/win64免安装jre环境运行
由于java 转为exe,只能在装有JDK环境的电脑运行, 发给其他人也不能运行,缺少环境,程序自己背着jre走 1.先打好jar 包 2.使用exe4j 把jar包转成exe 运行程序 3.使用inno stup ,把exe运行程序加上jre环境 以下是具体实现…...
算法板子:容斥原理——求出 1∼n 中能被质数 p1,p2,…,pm 中的至少一个数整除的整数有多少个
1. 题目要点 1. 设:求1~10中能被质数2和3中至少一个数整除的数有多少个。1~10中能被质数2整除的数的集合记为S1{2,4,6,8,10},能被质数3整除的数的集合记为S2{3,6,9},能同时被质数2和3整数的数的集合为S1∩S2{6} 2. 这道题的目的是求S1∪S2∪S…...
用gurobipy求解带不等式约束条件的优化问题
1. 引入 在当今的数据驱动世界中,优化问题无处不在,从工程设计到经济模型,再到机器学习算法的调参,优化都是实现效率最大化、成本最小化或性能最优化的关键工具。 这里有一个典型的数学优化问题,目标是在给定的约束条…...
漏洞复现-Adobe ColdFusion 远程代码执行漏洞(CVE-2023-38203)
1.漏洞描述 Adobe ColdFusion是一种服务器端的Web应用开发平台。它由Adobe Systems开发,用于创建动态的、交互式的Web应用程序和网站。 Adobe ColdFusion在2018u17及之前版本、2021u7及之前版本和2023u1及之前版本中存在任意代码执行漏洞。该漏洞是由于反序列化不…...
Spring-MyBatis整合:No qualifying bean of type ‘XXX‘ available: ...
1.看一下核心配置中有没有导入myBatis配置 2.看一下service和dao有没有相应注解 3.看一下MyBatisConfig中有没有对sqlSessionFactory和mapperScannerConfigurer注释成bean对象以及有没有配置映射文件路径...
gitea docker 快捷安装部署
前言 在前一篇博文(什么是 Gitea?)中,我们详细介绍了gitea的功能特性,以及其与其它git服务器之间的特性多维度对比。 在本文中,我们将详细介绍gitea的快捷安装部署,docker方式! 1…...
Charles证书过期别慌!Win10/Win11系统下彻底清除旧证书的保姆级教程
Charles证书过期别慌!Win10/Win11系统下彻底清除旧证书的保姆级教程 当你发现Charles突然无法正常抓取HTTPS流量,大概率是根证书过期了。作为Windows平台下最常用的抓包工具之一,Charles的证书管理直接影响着开发调试效率。但系统证书存储机制…...
3分钟上手:免费跨平台资源下载神器,轻松获取全网视频资源
3分钟上手:免费跨平台资源下载神器,轻松获取全网视频资源 【免费下载链接】res-downloader 视频号、小程序、抖音、快手、小红书、直播流、m3u8、酷狗、QQ音乐等常见网络资源下载! 项目地址: https://gitcode.com/GitHub_Trending/re/res-downloader …...
c++如何实现基于流缓冲区派生类的高级虚流映射与内存模拟文件【底层】
不能直接继承 std::streambuf 做“虚文件”,因其仅提供 underflow()/overflow() 等底层I/O操作,缺失 open/close/seek/stat 等文件语义,需自行实现 seekoff()(区分读写位置与 end 语义)、xsputn() 回退机制等ÿ…...
Sony-PMCA-RE:索尼相机自定义功能解锁与固件安全操作指南
Sony-PMCA-RE:索尼相机自定义功能解锁与固件安全操作指南 【免费下载链接】Sony-PMCA-RE Reverse Engineering Sony Digital Cameras 项目地址: https://gitcode.com/gh_mirrors/so/Sony-PMCA-RE 索尼相机逆向工具Sony-PMCA-RE是一款强大的开源工具ÿ…...
正式支持 Spring Boot 4、新增 Jackson3/Snack4 插件适配
目前最新版本 v1.45.0 已推送至 Maven 中央仓库 🎉,大家可以通过如下方式引入: <!-- Sa-Token 权限认证 --> <dependency><groupId>cn.dev33</groupId><artifactId>sa-token-spring-boot4-starter</artifa…...
从手动15秒到自动0.8秒:米哈游游戏扫码登录的智能革命
从手动15秒到自动0.8秒:米哈游游戏扫码登录的智能革命 【免费下载链接】MHY_Scanner MHY扫码登录器,支持从直播流抢码。 项目地址: https://gitcode.com/gh_mirrors/mh/MHY_Scanner 在直播抢码、多账号切换的激烈竞争中,你是否还在为手…...
Join-Monster多数据库支持:MySQL、PostgreSQL、SQLite的配置和优化指南
Join-Monster多数据库支持:MySQL、PostgreSQL、SQLite的配置和优化指南 【免费下载链接】join-monster A GraphQL to SQL query execution layer for query planning and batch data fetching. 项目地址: https://gitcode.com/gh_mirrors/jo/join-monster Jo…...
如何用Diablo Edit2解决暗黑破坏神II角色编辑难题?完整指南
如何用Diablo Edit2解决暗黑破坏神II角色编辑难题?完整指南 【免费下载链接】diablo_edit Diablo II Character editor. 项目地址: https://gitcode.com/gh_mirrors/di/diablo_edit 暗黑破坏神II作为一款经典的动作角色扮演游戏,其复杂的角色养成…...
从L2到Wing Loss:人脸关键点检测损失函数演进与实战解析
1. 人脸关键点检测与损失函数基础 人脸关键点检测是计算机视觉中的一项基础任务,需要精确定位眼睛、鼻子、嘴角等面部特征位置。这项技术在美颜相机、虚拟试妆、疲劳驾驶监测等场景中都有广泛应用。要让AI模型学会这项技能,关键在于设计合适的损失函数—…...
告别联网烦恼:uv离线安装科学计算包的3种实战姿势(NumPy/TensorFlow实测)
数据科学家必备:三种高效离线安装Python科学计算包的终极方案 实验室的服务器突然断网了,而你的TensorFlow模型训练正进行到关键时刻——这种场景对数据科学家来说简直是噩梦。别担心,离线安装Python包并非无解难题。本文将带你掌握三种经过实…...
