FloodFill算法简介(用BFS、DFS算法解决)

FloodFill算法中文名:洪水灌溉

FloodFill通常是这样一类问题,如下图:

负数表示凹陷的土地,正数表示凸起的土地,发洪水/下雨会淹没凹陷的地方

通常会问这几种问题:

1.被淹没的区域有几块

2.被淹没的最大区域面积

3.某块背淹没区域的边长是多少

..................

**本质问题:**找出这块区域中性质相同的连通块

连通块可以使上下左右四个方向连同,也可以是加上斜向八个方向连通

**解决方法:**DFS(深度优先遍历)、BFS(广度优先遍历)

1.DFS(深度优先遍历)

从某个位置开始深度搜素,例如从右上角-1位置开始,先向下到-2,再向下到-10,再向下到-12,-12位置无法继续向下或向左右,倒退回-10,再向左到-4,再向上到-3

2.BFS(广度优先遍历)

从某个位置开始广度搜索,例如从右上角-1位置开始,-1位置上下左右搜索到-2位置,再从-2位置上下左右搜索到-3和-10位置,再分别从-3和-10位置上下左右搜索到-4和-10位置,再从-4和-10位置上下左右搜索到-12位置

相关推荐
信奥卷王1 分钟前
[GESP202503 五级] 原根判断
java·数据结构·算法
兮山与2 分钟前
算法4.0
算法
nju_spy3 分钟前
力扣每日一题(二)任务安排问题 + 区间变换问题 + 排列组合数学推式子
算法·leetcode·二分查找·贪心·排列组合·容斥原理·最大堆
初听于你4 分钟前
高频面试题解析:算法到数据库全攻略
数据库·算法
翟天保Steven6 分钟前
ITK-基于Mattes互信息的二维多模态配准算法
算法
代码对我眨眼睛9 分钟前
226. 翻转二叉树 LeetCode 热题 HOT 100
算法·leetcode·职场和发展
黑色的山岗在沉睡1 小时前
LeetCode 494. 目标和
算法·leetcode·职场和发展
haoly19894 小时前
数据结构和算法篇-线性查找优化-移至开头策略
数据结构·算法·移至开头策略
学Linux的语莫7 小时前
机器学习数据处理
java·算法·机器学习
earthzhang20218 小时前
【1007】计算(a+b)×c的值
c语言·开发语言·数据结构·算法·青少年编程