BFS专题

1、BFS解决FloodFill算法

1、1图像渲染

733. 图像渲染 - 力扣(LeetCode)

class Solution 
{typedef pair<int,int> PII;int dx[4] = {0,0,1,-1};int dy[4] = {1,-1,0,0};
public:vector<vector<int>> floodFill(vector<vector<int>>& image, int sr, int sc, int color) {int n = image.size(), m = image[0].size();int aim = image[sr][sc];//标记像素值if(aim == color) return image;//处理边界情况queue<PII> q;q.push({sr,sc});//入第一个位置while(!q.empty()){auto [a,b] = q.front();//拿到对头q.pop();//然后删除,front和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 < n && y >= 0 && y < m && image[x][y] == aim)//符合条件{q.push({x,y});}}}return image;}
};

1、2岛屿数量

200. 岛屿数量 - 力扣(LeetCode)

class Solution 
{int dx[4] = {0,0,1,-1};//向量表示int dy[4] = {1,-1,0,0};bool vis[301][301];//标记int n,m;int res;typedef pair<int,int> PII;
public:void bfs(int i,int j,vector<vector<char>>& grid){queue<PII> q;q.push({i,j});vis[i][j] = true;while(!q.empty()){auto [a,b] = q.front();q.pop();//vis[a][b] = true;//不能在出队的时候才改变状态,否则前面的结点可能也会遍历到for循环里面已经找过的结点,结果会重复计算//必须遍历到是陆地的结点时,立马修改状态;否则就会引起重复计算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 && !vis[x][y] && grid[x][y] == '1'){vis[x][y] = true;q.push({x,y});}}}}int numIslands(vector<vector<char>>& grid) {n = grid.size(),m = grid[0].size();for(int i = 0;i<n;i++)for(int j = 0;j<m;j++){if(grid[i][j] == '1' && !vis[i][j]){res++;bfs(i,j,grid);//进去将相连的陆地标记}}return res;}
};

1、3岛屿的最大面积

695. 岛屿的最大面积 - 力扣(LeetCode)

class Solution 
{int res = 0;//最大岛屿面积int path;//当前陆地面积bool vis[51][51];//记录访问过的陆地int m,n;int dx[4] = {0,0,1,-1};//向量int dy[4] = {1,-1,0,0};typedef pair<int,int> PII;
public:void bfs(vector<vector<int>>& grid,int i,int j){queue<PII> q;q.push({i,j});int count = 0;vis[i][j] = true;while(!q.empty()){auto [a,b] = q.front();q.pop();count++;//vis[a][b] = true;//不能在出队的时候才改变状态,否则前面的结点可能也会遍历到for循环里面已经找过的结点,结果会重复计算//必须遍历到是陆地的结点时,立马修改状态;否则就会引起重复计算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]){vis[x][y] = true;q.push({x,y});}}}res = max(res,count);}int maxAreaOfIsland(vector<vector<int>>& grid) {m = grid.size(),n = grid[0].size();for(int i = 0;i<m;i++)for(int j = 0;j<n;j++){if(grid[i][j] == 1 && !vis[i][j]){bfs(grid,i,j);}}return res;}
};

1、4被围绕的区域

130. 被围绕的区域 - 力扣(LeetCode)

class Solution 
{   vector<vector<bool>> vis;int m,n;int dx[4] = {0,0,1,-1};int dy[4] = {1,-1,0,0};typedef pair<int,int> PII;
public:void bfs(vector<vector<char>>& board,int i,int j){queue<PII> q;q.push({i,j});vis[i][j] = true;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 < m && y >= 0 && y < n && board[x][y] == 'O' && !vis[x][y]){vis[x][y] = true;q.push({x,y});}}}}void solve(vector<vector<char>>& board) {m = board.size(), n =board[0].size();vis = vector<vector<bool>>(m,vector<bool>(n,false));//将在边上未被包围的岛屿的vis变为true;for(int j = 0;j<n;j++){if(!vis[0][j] && board[0][j] == 'O'){bfs(board,0,j);}if(!vis[m-1][j] && board[m-1][j] == 'O'){bfs(board,m-1,j);}                                              }for(int i = 0;i<m;i++){if(!vis[i][0] && board[i][0] == 'O'){bfs(board,i,0);}if(!vis[i][n-1] && board[i][n-1] == 'O'){bfs(board,i,n-1);}                                    }//再将矩阵内部的被包围并且没有被访问过的岛屿改为xfor(int i = 1;i<m-1;i++)for(int j = 1;j<n-1;j++){if(!vis[i][j] && board[i][j] == 'O'){board[i][j] = 'X';}}}};

2、BFS解决最短路径问题

边权为1的最短路问题

2、1迷宫中离入口最近的出口

1926. 迷宫中离入口最近的出口 - 力扣(LeetCode)

class Solution 
{int m,n;bool vis[101][101];int dx[4] = {0,0,1,-1};int dy[4] = {1,-1,0,0};typedef pair<int,int> PII;
public:int nearestExit(vector<vector<char>>& maze, vector<int>& e) {m = maze.size(), n = maze[0].size();queue<PII> q;q.push({e[0],e[1]});vis[e[0]][e[1]] = true;int count = 0;//步数while(!q.empty()){count++;//扩展一层int size = q.size();//当前队列中有多少元素,然后“同时出队”,同时bfsfor(int p = 0;p<size;p++){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 &&

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

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

相关文章

RIP环境下的MGRE 综合实验

实验题目及要求&#xff1a; 1.R5为ISP&#xff0c;只能进行IP地址配置&#xff0c;其所有地址均配为公有IP地址 2.R1和R5间使用PPP的PAP认证&#xff0c;R5为主认证方; R2于R5之间使用PPP的chap认证&#xff0c;R5为主认证方&#xff1b; R3于R5之间使用HDLC封装。 3.R1/…

【C++】为什么能实现函数重载

从C语言一路学到C的途中&#xff0c;C语言C语言相比&#xff0c;多了个函数重载&#xff0c;那么函数重载是如何实现的呢&#xff0c;为什么C语言无法支持&#xff0c;在本篇博客中&#xff0c;将会讲解C为何能实现函数重载。 一.编译过程 C能实现函数重载&#xff0c;而C语言不…

QT 二维坐标系显示坐标点及点与点的连线-通过定时器自动添加随机数据点

QT 二维坐标系显示坐标点及点与点的连线-通过定时器自动添加随机数据点 功能介绍头文件C文件运行过程 功能介绍 上面的代码实现了一个简单的 Qt 应用程序&#xff0c;其功能包括&#xff1a; 创建一个 MainWindow 类&#xff0c;继承自 QMainWindow&#xff0c;作为应用程序的…

2024软件设计师备考讲义——UML(统一建模语言)

UML的概念 用例图的概念 包含 <<include>>扩展<<exted>>泛化 用例图&#xff08;也可称用例建模&#xff09;描述的是外部执行者&#xff08;Actor&#xff09;所理解的系统功能。用例图用于需求分析阶段&#xff0c;它的建立是系统开发者和用户反复…

Pyppeteer中Chromium安装步骤

1、下载压缩文件 在官网下载chrome-win.zip文件 2、终端下载pyppeteer 首先在Pycharm终端运行pip install pyppeteer 3、查找文件默认路径 在运行以下代码&#xff0c;找到可执行文件默认路径 import pyppeteer.chromium_downloader print(默认版本是&#xff1a;{}.forma…

牛角工具箱源码 轻松打造个性化在线工具箱

&#x1f389; Whats this&#xff1f; 这是一款在线工具箱程序&#xff0c;您可以通过安装扩展增强她的功能 通过插件模板的功能&#xff0c;您也可以把她当做网页导航来使用~ 觉得该项目不错的可以给个Star~ &#x1f63a; 演示地址 https://tool.aoaostar.com &#x1f…

TCP网络协议栈和Posix网络部分API总结

文章目录 Posix网络部分API综述TCP协议栈通信过程TCP三次握手和四次挥手&#xff08;看下图&#xff09;三次握手常见问题&#xff1f;为什么是三次握手而不是两次&#xff1f;三次握手和哪些函数有关&#xff1f;TCP的生命周期是从什么时候开始的&#xff1f; 四次挥手通信状态…

HarmonyOS实战开发-如何实现一个自定义抽奖圆形转盘

介绍 本篇Codelab是基于画布组件、显式动画&#xff0c;实现的一个自定义抽奖圆形转盘。包含如下功能&#xff1a; 通过画布组件Canvas&#xff0c;画出抽奖圆形转盘。通过显式动画启动抽奖功能。通过自定义弹窗弹出抽中的奖品。 相关概念 Stack组件&#xff1a;堆叠容器&am…

从0开始搭建基于VUE的前端项目(一) 项目创建和配置

准备与版本 安装nodejs(v20.11.1)安装vue脚手架(@vue/cli 5.0.8) ,参考(https://cli.vuejs.org/zh/)vue版本(2.7.16),vue2的最后一个版本vue.config.js的配置详解(https://cli.vuejs.org/zh/config/)element-ui(2.15.14)(https://element.eleme.io/)vuex(3.6.2) (https://…

K8S命令行可视化实验

以下为K8s命令行可视化工具的实验内容&#xff0c;相比于直接使用命令行&#xff0c;可视化工具可能更直观、更易于操作。 Lens Lens是用于监控和调试的K8S IDE。可以在Windows、Linux以及Mac桌面上完美运行。在 Kubernetes 上&#xff1a; 托管地址&#xff1a;github/lensa…

机器人运动控制

一、基础 1.1 矢量速度和旋转速度 矢量速度用来控制运动方向&#xff0c;任何一个方向都可以看成x、y、z三轴方向的合。单位规定是m/s。 旋转速度用来控制旋转方向&#xff0c;可以看成x、y、z三轴方向旋转的合。单位规定是pi/s。 速度消息包&#xff0c;可以在ROS Index上搜…

助力福建新型职业农民培育 北方天途推进无人机植保应用培训

为加强新型职业农民的职业培育&#xff0c;扩展新型农民的知识范围和专业技术水平&#xff0c;推进农业供给侧结构性改革。日前&#xff0c;在农业部门的大力支持下&#xff0c;北方天途航空和宁德天禾科技服务携手为福建省农民朋友开展了植保无人机驾驶员的应用培训。福建省农…

网页布局案例 浮动

这里主要讲浮动 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title><style>*{padding: 0;margin: 0;}.header{height: 40px;background-color: #333;}.nav{width: 1226px;heig…

深入理解数据结构(2):顺序表和链表详解

文章主题&#xff1a;顺序表和链表详解&#x1f331;所属专栏&#xff1a;深入理解数据结构&#x1f4d8;作者简介&#xff1a;更新有关深入理解数据结构知识的博主一枚&#xff0c;记录分享自己对数据结构的深入解读。&#x1f604;个人主页&#xff1a;[₽]的个人主页&#x…

机器学习——降维算法-奇异值分解(SVD)

机器学习——降维算法-奇异值分解&#xff08;SVD&#xff09; 在机器学习中&#xff0c;降维是一种常见的数据预处理技术&#xff0c;用于减少数据集中特征的数量&#xff0c;同时保留数据集的主要信息。奇异值分解&#xff08;Singular Value Decomposition&#xff0c;简称…

csp资料

头文件 #include <bits/stdc.h> using namespace std isdigit(c); isalpha(c); switch(type){case value : 操作 } continue;//结束本轮循环 break;//结束所在的整个循环tips: //除法变乘法来算 //减法变加法 num1e42;//"1e4"表示10的4次方//用于移除容器中相…

某国投集团知识竞赛活动方案

一、抽签分组办法 1.抽签&#xff1a;参赛队伍赛前进行抽签分组。 2.分组&#xff1a;全部报名参赛队伍按照抽签顺序分为4组&#xff0c;每组7支队伍进行预赛&#xff0c;9月16日上午1、2组进行初赛&#xff0c;9月16日下午3、4组进行初赛。每组决出的前三名进入决赛。 二、初…

二维码门楼牌管理应用平台建设:引领现代化小区管理新篇章

文章目录 前言一、二维码门楼牌管理应用平台概述二、三维动态单体化技术的优势三、二维码门楼牌管理应用平台的应用场景四、展望未来 前言 随着城市化的快速推进&#xff0c;现代化小区如雨后春笋般涌现&#xff0c;对小区管理的效率和智能化提出了更高要求。二维码门楼牌管理…

鸿蒙OS开发实例:【瀑布流式图片浏览】

介绍 瀑布流式展示图片文字&#xff0c;在当前产品设计中已非常常见&#xff0c;本篇将介绍关于WaterFlow的图片浏览场景&#xff0c;顺便集成Video控件&#xff0c;以提高实践的趣味性 准备 请参照[官方指导]&#xff0c;创建一个Demo工程&#xff0c;选择Stage模型熟读Har…

图像分割论文阅读:Automatic Polyp Segmentation via Multi-scale Subtraction Network

这篇论文的主要内容是介绍了一种名为多尺度差值网络&#xff08;MSNet&#xff09;的自动息肉分割方法。 1&#xff0c;模型整体结构 整体结构包括编码器&#xff0c;解码器&#xff0c;编码器和解码器之间是多尺度差值模块模块&#xff08;MSM&#xff09;&#xff0c;以及一…