Graph Theory
Graph Theory
Breadth First Search (BFS)
Finds the shortest path from a source vertex to all other vertices in an unweighted graph.
Depth First Search (DFS)Explores as far as possible along each branch before backtracking, used to traverse or search in graphs.
Dijkstra's AlgorithmFinds the shortest path between nodes in a weighted graph, where the edges have non-negative weights.
Bellman-Ford AlgorithmFinds the shortest path between nodes in a weighted graph, even when the edges have negative weights.
Floyd-Warshall AlgorithmFinds the shortest paths between all pairs of nodes in a weighted graph. It works with both positive and negative edge weights.
Prim's AlgorithmFinds the minimum spanning tree (MST) of a weighted undirected graph, which connects all the vertices with the minimum total edge weight.
Kruskal's AlgorithmFinds the minimum spanning tree of a weighted undirected graph, also by selecting edges with minimum weight.
Topological SortArranges the nodes in a directed acyclic graph (DAG) in a linear order such that for every directed edge (u, v), node u comes before node v.
Strongly Connected Components (SCC)Identifies groups of nodes in a directed graph where each node is reachable from every other node in the same group.
Articulation Points and BridgesIdentifies critical nodes and edges in an undirected graph.
Tarjan's AlgorithmIdentifies strongly connected components in a directed graph.
Fleury's AlgorithmFinds an Eulerian circuit in a connected, directed or undirected graph.
Hierholzer's AlgorithmFinds an Eulerian circuit in a directed graph.
Bipartite Graph CheckDetermines if a given graph is bipartite, meaning its vertices can be divided into two disjoint sets such that no two adjacent vertices are in the same set.
Maximum FlowFinds the maximum flow in a flow network, which represents the movement of a resource from a source to a sink through a directed graph.
Minimum CutFinds the minimum cut in an undirected weighted graph.
Traveling Salesman Problem (TSP)Finds the shortest possible tour that visits each city exactly once and returns to the origin city.
Minimum Spanning ArborescenceFinds a minimum spanning arborescence (a directed spanning tree) in a directed graph.
A Search Algorithm*Finds the shortest path between nodes in a weighted graph, using a heuristic to guide the search.
Johnson's AlgorithmFinds the shortest paths between all pairs of vertices in a weighted, directed graph, even when there are negative edge weights.