前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >《python算法教程》Day6 - BFS遍历图(邻接字典)BFS简介代码示例

《python算法教程》Day6 - BFS遍历图(邻接字典)BFS简介代码示例

作者头像
billyang916
发布2018-05-02 10:21:01
9300
发布2018-05-02 10:21:01
举报
文章被收录于专栏:python读书笔记

这是《python算法教程》的第6篇读书笔记。笔记的主要内容为BFS(广度优先搜索,breath-first search)。

BFS简介

BFS会对图逐层访问记先访问某个节点的所有临接节点,之后再访问这个节点的其中一个临接节点的所有临接节点。以下图为例,BFS先访问a节点的邻接节点b、f;再访问b的邻接节点c、d、f;接下来访问a的另一个邻接节点 f 的邻接节点……

代码示例

BFS将遍历下图。

DAG.JPG

代码语言:javascript
复制
#迭代版bfs
import collections

def bfs(G,s):
    #P为记录每一个节点的父节点的字典
    P={s:None}
    Q=collections.deque()
    Q.append(s)
    while Q:
        u=Q.popleft()
        for v in G[u]:
            if v in P.keys():
                continue
            P[v]=P.get(v,u)
            Q.append(v)
    return P

#图的邻接字典
G={
    'a':{'b','f'},
    'b':{'c','d','f'},
    'c':{'d'},
    'd':{'e','f'},
    'e':{'f'},
    'f':{}
}

P=bfs(G,'a')
print(P)


#获取a至e的路径
u='e'
path=[u]
while P[u] is not None:
    path.append(P[u])
    u=P[u]
path.reverse()
print(path)
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.04.16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • BFS简介
  • 代码示例
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档