BFS广度优先算法

写给自己看
广度优先搜索算法(Breadth-First Search,BFS)是一种盲目搜寻法,目的是系统地展开并检查图中的所有节点,以找寻结果。换句话说,它并不考虑结果的可能位置,彻底地搜索整张图,直到找到结果为止。
代码来自:https://blog.csdn.net/u012285175/article/details/84950563

# -*- encoding: utf-8 -*-
from collections import deque


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("%s is a mango seller!" % person)
                return True
            else:
                search_queue += graph[person]
                searched.append(person)  # 将这个人标记为检查过
    return False


def person_is_seller(man):  # 判断是否为芒果经销商
    print(man[-1])
    return man[-1] == "m"//判断字符串最后一个字符是否为m


if __name__ == "__main__":
    graph = {}
    graph["you"] = ["alice", "bob", "claire"]
    graph["bob"] = ["anuj", "peggy"]
    graph["alice"] = ["peggy"]
    graph["claire"] = ["thom", "jonny"]
    graph["anuj"] = []
    graph["peggy"] = []
    graph["thon"] = []
    graph["jonny"] = []

    search("you")

以代码中的例子说明:创建一个队列,从一个点(you)开始,首先遍历"you"里面的,按顺序分别是:“alice”, “bob”, “claire”。遍历之后找到和"alice"相关的:“peggy”,然后找到与"bob"相关的:“anuj”, “peggy”,若是当前点已经遍历过,则不会遍历第二次,接着过一遍"claire"相关的:“thom”, “jonny”

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值