BFS模板

Posted zeooo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BFS模板相关的知识,希望对你有一定的参考价值。

  1. 如果不需要确定当前遍历到了哪一层,BFS模板如下。
while queue 不空:
    cur = queue.pop()
    for 节点 in cur的所有相邻节点:
        if 该节点有效且未访问过:
            queue.push(该节点)
  1. 如果要确定当前遍历到了哪一层,BFS模板如下。
    这里增加了level表示当前遍历到二叉树中的哪一层了,也可以理解为在一个图中,现在已经走了多少步了。size表示在当前遍历层有多少个元素,也就是队列中的元素数,我们把这些元素一次性遍历完,即把当前层的所有元素都向外走了一步。
level = 0
while queue 不空:
    size = queue.size()
    while (size --) {
        cur = queue.pop()
        for 节点 in cur的所有相邻节点:
            if 该节点有效且未被访问过:
                queue.push(该节点)
    }
    level ++;

以上是关于BFS模板的主要内容,如果未能解决你的问题,请参考以下文章

[bfs] aw190. 字串变换(双向广搜+模板题)

VSCode自定义代码片段——.vue文件的模板

BFS算法模板与练习

[A*] aw179. 八数码(A*+bfs最小步数模型+模板题)

VSCode自定义代码片段1——vue主模板

VSCode自定义代码片段2——.vue文件的模板