Graph Algorithms for DAA LAB Submission
- Goto build directory
- Delete all of its contents
- run the following sequentially in the terminal opened at build directory
- cmake ..
- make
- ./graph
Note: Install cmake in your pc if not already installed.
A void function that performs DFS on the graph G and prints out the DFS tree. It performs DFS untill all vertices are visited. It also keeps track of the number of connected components and prints it at the end. Parameters:
- A object G of the graph class
Print the DFS tree covering all vertices. Also print the number of connected components.
A void function that performs DFS on the graph G and prints out the DFS tree starting at a given source vertex s. Parameters:
- A object G of the graph class
- integer denoting the source vertex
Print the DFS tree starting at source vertex s.
A boolean function returns if the vertex t is reachable from vertex s using DFS. Parameters:
- A object G of the graph class
- integer s denoting the source vertex
- integer t denoting the end vertex
Boolean value denoting if t is reachable from s.
A void function that performs BFS on the graph G and prints out the BFS tree. It performs DFS untill all vertices are visited. It also keeps track of the number of connected components and prints it at the end. Parameters:
- A object G of the graph class
Print the BFS tree covering all vertices. Also print the number of connected components.
A void function that performs BFS on the graph G and prints out the BFS tree starting at a given source vertex s. Parameters:
- A object G of the graph class
- integer denoting the source vertex
Print the BFS tree starting at source vertex s.
A boolean function returns if the vertex t is reachable from vertex s using BFS. Parameters:
- A object G of the graph class
- integer s denoting the source vertex
- integer t denoting the end vertex
Boolean value denoting if t is reachable from s.
A void function that prints the single source shortest distance path from vertex s. The flag value denotes if the given graph is weighted or unweighted. Parameters:
- A object G of the graph class
- integer s denoting the source vertex
- integer flag which denotes:
- flag = 0 implies graph is unweighted
- flag = 1 implies graph is weighted
At the moment, the algorithm for weighted graphs is only coded to handle positive weights.
Prints the SPATH of all vertices from given source vertex and the respective path length.
A void function that prints the longest path in the input tree using BFS (twice). Parameters:
- A object T of the graph class
Input graph must be a Tree.
Prints the LPATH in the tree.
A void function that prints the longest path in a Directed Acyclic Graph using Topological sorting. Parameters:
- A object G of the graph class
Input graph must be a Directed Acyclic Graph.
Prints the LPATH in the input DAG.
A void function that finds the maximum edge weight spanning tree in the input graph using modified Kruskal algorithm. Parameters:
- A object G of the graph class
Input graph must be a undirected.
Prints the adjacency matrix of max weight spanning tree and also prints the maximum weight.
A boolean function that test if input graph G is bipartite or not. It achieves by checking if graph is 2-colorable using BFS algorithm. Parameters:
- A object G of the graph class
Returns a boolean value indicating if the input graph is bipartite or not. (1/0)
A void function that prints all the articulation points in the input graph in linear time using Tarjan's algorithm. Parameters:
- A object G of the graph class
Prints all the articulation points in the input graph.
A void function that prints all the bridges in the input graph in linear time using Tarjan's algorithm. Parameters:
- A object G of the graph class
Prints all the bridges (u,v) in the input graph.
A void function that finds the minimum edge weight spanning tree in the input graph using Kruskal algorithm. Parameters:
- A object G of the graph class
Input graph must be a undirected.
Prints the adjacenct matrix of min weight spanning tree and also prints the minimum weight.
A void function that finds the minimum edge weight spanning tree in the input graph using Prim's algorithm. Parameters:
- A object G of the graph class
Input graph must be a undirected.
Prints the adjacency matrix of min weight spanning tree and also prints the minimum weight.
A void function that finds the minimum edge weight spanning tree in the input graph using Reverse Delete algorithm. In the above algorithm, we first sort the edges in descending order. Then we pick the edge with the max edge weight and check if its removal makes the graph disconnected. If it does not we remove it. We proceed until we only have N-1 edges left. Parameters:
- A object G of the graph class
Input graph must be a undirected.
Prints the adjacency matrix of min weight spanning tree and also prints the minimum weight.