您当前的位置: 首页 >  数据结构
  • 2浏览

    0关注

    880博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

【大话数据结构C语言】44 图的广度优先遍历

CodeAllen嵌入式编程 发布时间:2021-05-09 23:50:57 ,浏览量:2

欢迎关注我的公众号是【CodeAllen】,关注回复【1024】获取资源 程序员技术交流①群:736386324 ,程序员技术交流②群:371394777    

广度优先遍历(BreadthFirstSearch),又称为广度优先搜索,简称BFS。
 
如果以之前我们找钥匙的例子来讲,运用深度优先遍历意味着要先彻底查找完一个房间再开始另一个房间的搜索。
但我们知道,钥匙放在沙发地下等犄角旮旯的可能性极低,因此我们运用新的方案: 先看看钥匙是否放在各个房间的显眼位置,如果没有,再看看各个房间的抽屉有没有。这样逐步扩大查找的范围的方式我们称为广度优先遍历。
 
 
将下图左侧图变形,变形原则是A放置在最上边第一层,让其与它右边的顶点B F为第二层,再让与B F有边的顶点C I G E为第三层,再将这四个顶点有边的D H放在第四层,就如下方右侧图
两个图在视觉上感觉发生了变化,其实顶点和边的关系还是完全相同的

 
 
 
要实现对图的广度遍历,我们可以利用队列来实现

 
BTSTraverse.c
// 邻接矩阵的广度遍历算法
void BFSTraverse(MGraph G)
{
    int i, j;
    Queue Q;
    
    for( i=0; i             
关注
打赏
1665938897
查看更多评论
0.0445s