BFS广度优先遍历代码详解,python3

graph = {
        "A": ["B", "C", "D"],
        "B": ["A", "C", "E"],
        "C": ["A", "B", "F"],
        "D": ["A", "F"],
        "E": ["B", "G"],
        "F": ["C", "D", "H"],
        "G": ["E"],
        "H": ["F", "I"],
        "I": ["H"]
        }
def BFS(graph, s):        #将广度优先遍历定义为函数,代入的参数有待遍历的数列和起始遍历的结点
    queue = []            #设置一个列表存放待遍历的结点
    queue.append(s)     
    seen = set()          #存放已经访问的结点
    seen.add(s)         
    while(len(queue) > 0):      #列表不为空的时候开始遍历
        vertex = queue.pop(0)   #弹出列表中待遍历的结点赋值给vertex
        nodes = graph[vertex]   #将本次被遍历的点的所有邻接点放入nodes
        for w in nodes:         #遍历被弹出的结点的扩展结点
            if w not in seen:   #遍历扩展结点,若该节点没有被访问过,则添加到数列中,开始新一轮的遍历
                queue.append(w)
                seen.add(w)     #将访问过的结点存入集合中
        print(vertex)           #输出本次访问的结点

BFS(graph, "A")
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值