Mini Shell

Direktori : /opt/imh-python/lib/python3.9/site-packages/pygraph/functions/searching/
Upload File :
Current File : //opt/imh-python/lib/python3.9/site-packages/pygraph/functions/searching/breadth_first_search.py

"""Implementation of Breadth First Search."""

from collections import deque, defaultdict

def breadth_first_search(graph, root_node=None):
    """Searches through the tree in a breadth-first fashion.
        If root_node is None, an arbitrary node will be used as the root.
        If root_node is not None, it will be used as the root for the search tree.
        Returns a list of nodes, in the order that they were reached.
    """
    ordering = []

    all_nodes = graph.get_all_node_ids()
    if not all_nodes:
        return ordering

    queue = deque()
    discovered = defaultdict(lambda: False)
    to_visit = set(all_nodes)

    if root_node is None:
        root_node = all_nodes[0]

    discovered[root_node] = True
    queue.appendleft(root_node)

    # We need to make sure we visit all the nodes, including disconnected ones
    while True:
        # BFS Main Loop
        while len(queue) > 0:
            current_node = queue.pop()
            ordering.append(current_node)
            to_visit.remove(current_node)

            for n in graph.neighbors(current_node):
                if not discovered[n]:
                    discovered[n] = True
                    queue.appendleft(n)

        # New root node if we still have more nodes
        if len(to_visit) > 0:
            node = to_visit.pop()
            to_visit.add(node)  # --We need this here because we remove the node as part of the BFS algorithm
            discovered[node] = True
            queue.appendleft(node)
        else:
            break

    return ordering

Zerion Mini Shell 1.0