微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python-广度优先搜索

如图所示:

分享图片

 

以此图为例寻找末尾为“m”的名称。这里使用广度优先搜索,这个可以回答两类问题:

第一类问题:从节点A出发,有前往节点B的路径吗?

第二类问题:从节点A出发,前往节点B的哪条路径最短?

那这里其实就是寻找末尾为“m”名称的最短路径。

from collections import deque


def person_is_seller(name):
return name[-1] == ‘m‘

graph = {}
graph["you"] = ["alice","bob","claire"]
graph["bob"] = ["anuj","peggy"]
graph["alice"] = ["peggy"]
graph["claire"] = ["thom","jonny"]
graph["anuj"] = []
graph["peggy"] = []
graph["thom"] = []
graph["jonny"] = []

def search(name):
search_queue = deque()
search_queue += graph[name]
searched = []
while search_queue:
person = search_queue.popleft()
if person not in searched:
if person_is_seller(person):
print(person + ‘ is a mongo seller‘)
return True
else:
search_queue += graph[person]
searched.append(person)
return False

search("you")

这里使用到了散列表的概念,以及Python中deque函数来创建一个双端队列。 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐