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

C++宽度优先搜索算法(BFS算法):FloodFill问题模型

        前面我们已经学习了用队列和优先级队列解决宽度优先算法的问题。本期我们就来利用BFS算法解决另一个重要的模型——FloodFill问题。

        相关代码已经上传至作者的个人gitee:楼田莉子/C++算法学习喜欢请点个赞谢谢

目录

FloodFill问题介绍

1、图像渲染

2、岛屿数量

3、岛屿的最大面积

4、被围绕的区域


FloodFill问题介绍

        在解决算法题之前我们需要了解什么是FloodFill问题。

        FloodFill问题中文直译就是“洪水灌溉”问题。

        如下图所示,这是一块田地。

        它并不是一马平川的,而是凹凸不平的。就像下图所示,正数表示突起,负数表示凹陷

        洪水来临的时候会把凹下去的位置填满水,突起的地方不会,被包围的地方不会(本图里没有展示)

        本质上就是找到性质相同的连通块。        

1、图像渲染

        算法思想:BFS

        

        向量数组:

        

class Solution {
public:typedef pair<int ,int> PI;//向量数组int dx[4]={0,0,1,-1};int dy[4]={1,-1,0,0};vector<vector<int>> floodFill(vector<vector<int>>& image, int sr, int sc, int color) {    int m=image.size(),n=image[0].size();int prev=image[sr][sc];//标记要修改的像素值if(prev==color) return image;queue<PI>q;q.push({sr,sc});while(!q.empty()){auto [a,b]=q.front();q.pop();image[a][b] =color;//遍历四个方向for(int i=0;i<4;i++){int x=a+dx[i],y=b+dy[i];if(x>=0&&x<m&&y>=0&&y<n&&image[x][y]==prev){q.push({x,y});}}}   return image;}
};

2、岛屿数量

        算法思路:

        算法一:修改原有数组

        不过这个思路需要斟酌,因为力扣提供的是一个接口的形式,面试的时候需要询问是否可以修改,如果可以才可以使用

        算法二:搞一个vis数组,为bool类型,存储true和false。如果遍历过则为true反之为false

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

3、岛屿的最大面积

         算法思想:

class Solution {//向量数组int dx[4] = { 0,0,1,-1 };int dy[4] = { 1,-1,0,0 };//vis数组bool vis[51][51];int m, n;
public:int bfs(vector<vector<int>>& grid, int i, int j){//旧写法// int count=0;// queue<pair<int, int>>q;// q.push({ i,j });// vis[i][j] = true;// count++;// while (!q.empty())// {//     auto [a, b] = q.front();//     q.pop();//     for (int i = 0; i < 4; i++)//     {//         int x = a + dx[i], y = b + dy[i];//         if (x >= 0 && x < m && y >= 0 && y < n && //             grid[x][y] == 1 && vis[x][y] == false)//         {//             q.push({ x,y });//             vis[x][y] = true;//             count++;//         }//     }// }// return count;//新写法int count = 0;queue<pair<int, int>> q;q.push({ i, j });vis[i][j] = true;count++;while (q.size()){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 < m && y >= 0 && y < n&& grid[x][y] == 1 && !vis[x][y]){q.push({ x, y });vis[x][y] = true;count++;}}}return count;}int maxAreaOfIsland(vector<vector<int>>& grid){m = grid.size(), n = grid[0].size();int ret = 0;for (int i = 0; i < m; i++){for (int j = 0; j < n; j++){if (grid[i][j] == 1 && !vis[i][j]){ret = max(ret, bfs(grid, i, j));}}}return ret;}
};

4、被围绕的区域

        算法思想:

        1、先扫描边界上的O区域

        2、扫描矩阵,还原即可

class Solution {//向量数组int dx[4] = { 0,0,1,-1 };int dy[4] = { 1,-1,0,0 };int m, n;
public:void bfs(vector<vector<char>>& board,int i,int j){queue<pair<int ,int >>q;q.push({i,j});board[i][j]='.';while (q.size()){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 < m && y >= 0 && y < n&& board[x][y]=='O'){q.push({ x, y });board[x][y]='.';}}}}void solve(vector<vector<char>>& board) {m=board.size(),n=board[0].size();//先处理边界上的’O‘,然后转换成'.'for(int i=0;i<n;i++){if(board[0][i]=='O') bfs(board,0,i);if(board[m-1][i]=='O') bfs(board,m-1,i);}for(int j=0;j<m;j++){if(board[j][0]=='O') bfs(board,j,0);if(board[j][n-1]=='O') bfs(board,j,n-1);}//还原for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(board[i][j]=='O') board[i][j]='X';if(board[i][j]=='.') board[i][j]='O';}}}
};

        本期内容就到这里了,喜欢请点个赞谢谢。


文章转载自:

http://G4XNAzsO.rcfxq.cn
http://w7mHh18Q.rcfxq.cn
http://tHI19A3j.rcfxq.cn
http://WgrYMXKO.rcfxq.cn
http://GkvLHBqw.rcfxq.cn
http://P8EFOU9V.rcfxq.cn
http://MItkS1ZU.rcfxq.cn
http://AlcWNisw.rcfxq.cn
http://yUfmYf8Y.rcfxq.cn
http://aF2gt2Co.rcfxq.cn
http://RbVd71af.rcfxq.cn
http://2vwB5HJ6.rcfxq.cn
http://fNBieEfj.rcfxq.cn
http://KMA1ZLGJ.rcfxq.cn
http://SY8EXORy.rcfxq.cn
http://eLRUE48U.rcfxq.cn
http://XVWrjRm6.rcfxq.cn
http://icmdrocY.rcfxq.cn
http://RqK2IJJN.rcfxq.cn
http://7bhZwb9t.rcfxq.cn
http://Qu4IYCpZ.rcfxq.cn
http://IaignhE0.rcfxq.cn
http://Xnli2XJ4.rcfxq.cn
http://2ox2ibHt.rcfxq.cn
http://db7m9huu.rcfxq.cn
http://8rSNaC36.rcfxq.cn
http://lA4Gq0TV.rcfxq.cn
http://vY9UMUpa.rcfxq.cn
http://uc4bvMWH.rcfxq.cn
http://j3ChNhEQ.rcfxq.cn
http://www.dtcms.com/a/388455.html

相关文章:

  • ThreadLocal 的工作原理
  • Windows 11 下载安装 CosyVoice2,一键启动
  • 《Vuejs设计与实现》第 16 章(解析器) 下
  • JavaSE——图书系统项目
  • PHP 中 Class 的使用说明
  • Android入门到实战(九):实现书架页——RecyclerView + GridLayoutManager + 本地数据库
  • 日常开发-20250917
  • 基于SpringBoot+Vue的近郊农场共享管理系统(Echarts图形化分析)
  • AI开发实战:从数据准备到模型部署的完整经验分享
  • 【漏洞预警】大华DSS数字监控系统 user_edit.action 接口敏感信息泄露漏洞分析
  • RFID赋能光伏电池片制造智能化跃迁
  • 大数据 + 分布式架构下 SQL 查询优化:从核心技术到调优体系
  • FPGA硬件设计-DDR
  • 卫星通信天线的跟踪精度,含义、测量和计算
  • 忘记MySQL root密码,如何急救并保障备份?
  • Java 异步编程实战:Thread、线程池、CompletableFuture、@Async 用法与场景
  • 贪心算法应用:硬币找零问题详解
  • while语句中的break和continue
  • 10cm钢板矫平机:一场“掰直”钢铁的微观战争
  • Python实现计算点云投影面积
  • C++底层刨析章节二:迭代器原理与实现:STL的万能胶水
  • 学习Python中Selenium模块的基本用法(14:页面打印)
  • 便携式管道推杆器:通信与电力基础设施升级中的“隐形推手”
  • leetcode 349 两个数组的交集
  • UV映射!加入纹理!
  • 车辆DoIP声明报文/识别响应报文的UDP端口规范
  • Elasticsearch 2.x版本升级指南
  • OpenCV 人脸检测、微笑检测 原理及案例解析
  • [Python编程] Python3 集合
  • [性能分析与优化]伪共享问题(perf + cpp)