广度优先遍历
广度优先遍历是层次遍历,一次访问所有的邻接点,先访问的邻接点其邻接点也先被访问。可借助队列来实现。可设置一个辅助数组,表示第i个顶点是否被访问。
visited[i]=false;
初始化一个空的队列,queue
从图中的某个顶点u开始,将u入队。
如果队列不是空的,继续访问,否则算法结束。
队头元素v出队,依次访问所有未被访问的邻接点,标记已访问并入队,继续执行重复上一步。
那么如何用算法实现呢?
下面我们举个栗子。基于邻接矩阵的广度优先遍历。
void BFS_AM(int u)
{
queue
visted[u]=true;
Q.push(u);//让u入队
while(!Q.empty()){
int v=Q.front();//取队头
Q.pop();//出队
for(int w=1;w<=n;w++)
{
if(E[v][w]&&!visited[w])
{
visited[w]=true;
}
}
}
}
分类:
C++
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!