BFS算法框架

这里给出BFS基本算法框架,核心就是借助队列这种数据结构,每次遍历将一个节点的所有邻居节点加入到队列,然后按照队列 FIFO 的特性,实现BFS算法。

python 复制代码
# BFS 算法框架
#  计算从起点 start 到终点 target 的最近距离
def bfs(start, traget):
    step = 0
    # 核心数据结构
    queue = []
    # 避免走回头路
    visited = []
    # 将起点加入队列中
    queue.append(start)
    visited[start] = True

    while queue:
        sz = len(queue)
        for i in range(sz):
            cur = queue.pop()
            # 划重点:这⾥判断是否到达终点
            if cur == traget:
                return step

            for neighbor in cur.adj():
                if not visited[neighbor]:
                    queue.append(neighbor)
                    visited[neighbor] = True

        step += 1
    
    return step
相关推荐
拼好饭和她皆失21 小时前
《图论算法入门:掌握DFS和BFS,理解图与树的遍历》
深度优先·图论·宽度优先
Q741_1473 天前
C++ 队列 宽度优先搜索 BFS 力扣 662. 二叉树最大宽度 每日一题
c++·算法·leetcode·bfs·宽度优先
鹿角片ljp3 天前
力扣112. 路径总和:递归DFS vs 迭代BFS
leetcode·深度优先·宽度优先
wen__xvn4 天前
算法基础集训第19天:广度优先搜索
算法·宽度优先
豆沙沙包?5 天前
2026年--Lc343-1926. 迷宫中离入口最近的出口(图 - 广度优先搜索)--java版
java·算法·宽度优先
iAkuya6 天前
(leetcode)力扣100 45二叉树的右视图(dfs,bfs)
leetcode·深度优先·宽度优先
豆沙沙包?8 天前
2026年--Lc342-841. 钥匙和房间(图 - 广度优先搜索)--java版
java·算法·宽度优先
山顶夕景8 天前
【BFS】两壶水倒出k升水
算法·leetcode·bfs·宽度优先
iAkuya10 天前
(leetcode)力扣100 41二叉树的层序遍历(bfs)
windows·leetcode·宽度优先
Q741_14713 天前
C++ 队列 宽度优先搜索 BFS 力扣 429. N 叉树的层序遍历 每日一题
c++·算法·leetcode·bfs·宽度优先