Breadth-First Search (BFS) is a strategy for searching in a graph that priotitizes breadth.
BFS begins at a root node and inspects all the neighboring nodes. Then for each of those neighbor nodes in turn, it inspects their neighbor nodes which were unvisited, and so on. This function returns the nodes in the order they were visited as an array.
import { breadthFirstSearch } from "functional-algos";
const graph = new Map<string, string[]>([
["A", ["B", "D"]],
["B", ["A", "C"]],
["C", ["B"]],
["D", ["A", "E"]],
["E", ["D"]],
]);
const result = breadthFirstSearch(graph, "A");
Also used in the tests
Using a graph consisting of numbers:
graph TD
1 <--> 2
1 <--> 4
2 <--> 3
4 <--> 5
Returns [1, 2, 4, 3, 5]
Using a graph consisting of strings:
graph TD
A <--> B
A <--> D
B <--> C
D <--> E
Returns ["A", "B", "D", "C", "E"]