BFS又名广度优先搜索,和DFS算法一样都是递归算法,不同的是,BFS算法通过队列,在避免循环的同时遍历目标所有节点。,以具有5个节点的无向图为例,如下图:,从节点0开始,BFS算法首先将其放入Visited列表并将其所有相邻节点放入队列。,接下来,访问队列前面的节点1,并转到节点1相邻的节点。因为节点0已经被访问过,所以访问节点2。,节点2有一个未访问的相邻节点4,但因为节点4在队列的最后,因此我们要先访问位于队列前面的节点3。,队列中只剩下节点4没有被访问,所以最后访问节点4。,至此,已经完成了此无向图的广度优先遍历。,