news 2026/5/16 4:25:21

【广度优先搜索BFS】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【广度优先搜索BFS】

【BFS】

推荐视频链接
推荐好文

核心思想:层层递进,先广后深

运用手段:队列

简述:(推荐好文中有详述)

简单的说,就像石子落入水中溅起涟漪,一环一环,不断向周围扫过去。而“一环一环”就是通过队列实现的。首先将起点入队,之后取得他的坐标后便将他出队,然后根据这个坐标对其周围的点一 一扫过去,也就是一 一将他们入队,同时标记,之后都是只取队首的元素,取完后就出队,循环下去;

例题:

1.遍历

思路:
在边上的0一定不是围起来
所以只要找边上的就0,再涟漪过去

代码:

#include<bits/stdc++.h>usingnamespacestd;intn;vector<vector<int>>g(50,vector<int>(50)),s(50,vector<int>(50,0));//g表地图,s表判断数组structnode//想将一个坐标压入队列中,需要借助结构体或者二元数组{intx,y;};queue<node>qu;//队列intdx[]={1,-1,0,0};//方向数组intdy[]={0,0,-1,1};voidbfs(intx,inty){s[x][y]=1;//将起点标记qu.push((node){x,y});//让起点进队while(qu.size())//如果队列非空{intax=qu.front().x,ay=qu.front().y;//取队首元素qu.pop();//用完了就扔for(inti=0;i<4;i++)//方向{intsx=ax+dx[i],sy=ay+dy[i];if(sx>=1&&sx<=n&&sy>=1&&sy<=n&&!s[sx][sy])//不能出地图,不能是标记过的{s[sx][sy]=1;//标记qu.push((node){sx,sy});//再让这个坐标入队}}}}signedmain(){ios::sync_with_stdio(false);cin.tie(0);cin>>n;for(inti=1;i<=n;i++){for(intj=1;j<=n;j++){cin>>g[i][j];}}s=g;//让判断数组先与地图相等for(inti=1;i<=n;i++){for(intj=1;j<=n;j++){if(i==1||j==1||i==n||j==n)//如果是在边上的0的话就一个不是围起来的0{if(g[i][j]==0&&!s[i][j])//不能是判断过的{bfs(i,j);}}}}for(inti=1;i<=n;i++){for(intj=1;j<=n;j++){if(s[i][j]==1&&g[i][j]==1)cout<<1<<" ";//仔细想想elseif(s[i][j]==1&&!g[i][j])cout<<0<<" ";elseif(!s[i][j]&&!g[i][j])cout<<2<<" ";}cout<<endl;}return0;}

2.最短距离

代码:

#include<bits/stdc++.h>usingnamespacestd;//bfs用的不是递归,而是循环charg[1005][1005];//地图ints[1005][1005];//不在是判断数组,而是从起点走到每个位置的最短路程structnode//依旧{intx,y;};intdx[]={1,0,0,-1};//依旧intdy[]={0,1,-1,0};intn;queue<node>qe;intx1,yz,x2,y2;voidbfs(intx,inty){g[x][y]='1';qe.push((node){x,y});while(qe.size()){intax=qe.front().x,ay=qe.front().y;qe.pop();for(inti=0;i<4;i++){intsx=ax+dx[i],sy=ay+dy[i];if(sx>=1&&sx<=n&&sy>=1&&sy<=n&&g[sx][sy]=='0'){g[sx][sy]='1';s[sx][sy]=s[ax][ay]+1;//重点在这,每格=上一格+1步qe.push((node){sx,sy});if(sx==x2&&sy==y2)return;//如果找到了就退出就行了}}}}signedmain(){ios::sync_with_stdio(false);cin.tie(0);cin>>n;for(inti=1;i<=n;i++){for(intj=1;j<=n;j++){cin>>g[i][j];}}cin>>x1>>yz>>x2>>y2;bfs(x1,yz);cout<<s[x2][y2];return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/14 1:27:36

AMAT 0020-21033 刀片

AMAT 0020-21033 刀片相关信息AMAT 0020-21033 是 Applied Materials&#xff08;应用材料公司&#xff09;生产的一款半导体设备刀片组件&#xff0c;通常用于晶圆加工设备中。这类刀片在半导体制造过程中用于切割、抛光或其他精密加工步骤。关键特性兼容性&#xff1a;该刀片…

作者头像 李华
网站建设 2026/5/9 18:59:26

毕业季必看!6款AI论文神器实测:真实参考文献、轻松搞定毕业论文

如果你是正在熬夜赶Deadline的毕业生... 如果你正盯着电脑屏幕发呆&#xff0c;被导师的“进度催命符”轰炸&#xff1b;如果你翻遍知网只为找几篇能用的参考文献&#xff0c;却被高昂的查重费压得喘不过气&#xff1b;如果你是囊中羞涩的大学生&#xff0c;或是怕延毕的研究生…

作者头像 李华
网站建设 2026/5/14 17:45:20

vue和springboot框架开发的旅游分享点评网系统_c6l4qb5f

文章目录 具体实现截图主要技术与实现手段关于我本系统开发思路java类核心代码部分展示结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 同行可拿货,招校园代理 vuesprivuespringboot_c6l4qb5f 框架开发的旅游分享…

作者头像 李华
网站建设 2026/5/9 8:18:27

vue和springboot框架开发的民宿预定信息退订系统_777cb4oy

文章目录具体实现截图主要技术与实现手段关于我本系统开发思路java类核心代码部分展示结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;具体实现截图 同行可拿货,招校园代理 vuesprivuespringboot_777cb4oy 框架开发的民宿预定…

作者头像 李华
网站建设 2026/5/9 8:19:06

concurrentHashMap原理

concurrentHashMap的是为了解决HashMap在并发环境中出现的线程安全问题&#xff0c;同时也优化了HashTable在高并发中存在的性能问题&#xff0c;让其性能更接近于HashMap。高并发问题HashMap1.数据丢失问题2.JDK1.7采用头插法&#xff0c;会导致链表成环&#xff0c;抛出Concu…

作者头像 李华