Author: Samuel Lazareanu (sam.lazareanu@gmail.com)
This repository contains C++ implementations of graph algorithms. The graph is represented using an adjacency matrix.
The algorithms are designed to handle both directed and undirected graphs and weighted or unweighted.
Algorithms include connectivity check, shortest path, cycle detection, bipartiteness check, and negative cycle detection.
The integration of helper functions within the main algorithms enhances modularity, readability, and maintainability of the codebase. Each helper function serves a distinct purpose and contributes to the overall functionality of the algorithms.
-
isConnected(Graph)
: Determines whether the graph is connected or not. Utilizes Depth First Search (DFS) algorithm. -
shortestPath(Graph, size_t, size_t)
: Finds the shortest (or lightest-weighted) path between two vertices in the graph. Utilizes Bellman-Ford algorithm. -
isContainsCycle(Graph)
: Detects the presence of any cycle in the graph. Utilizes Depth First Search (DFS) algorithm. -
isBipartite(Graph)
: Checks if a graph can be partitioned into two sets such that no two vertices within the same set are adjacent. Utilizes Breadth First Search (BFS) algorithm. -
negativeCycle(Graph)
: Identifies the presence of a negative cycle in the graph, if any. Utilizes Bellman-Ford algorithm.
These algorithms are implemented in the helper functions mentioned below.
DFS is used to traverse through the graph in a depth first search. It's used in the isContainsCycle(Graph)
, isConnected(Graph)
functions.
BFS is used to explore all the vertices of the graph in a breath first search. It's used in the isBipartite(Graph)
function.
Bellman-Ford algorithm is utilized for finding the shortest path in a weighted graph with negative weight edges - shortestPath(Graph, size_t, size_t)
.
A graph is represented using an adjacency matrix.
-
loadGraph(vector<vector<int>>)
: Loads the provided adjacency matrix into the graph object. Makes sure the matrix is square. -
printGraph()
: Prints the adjacency matrix representation of the graph and stats related to it. -
getSize()
: Returns the size of the adjacency matrix (number of vertices). -
getWeight(size_t, size_t) const
: Returns the weight of the edge between two vertices (0 = no edge). -
getCycles() const
: Returns the flag indicating whether cycles were detected in the graph. -
getNegativeCycles() const
: Returns the flag indicating whether negative cycles were detected in the graph. -
setCycles(bool)
: Sets the flag indicating the presence of cycles in the graph. -
setNegativeCycles(bool)
: Sets the flag indicating the presence of negative cycles in the graph.
- Clone the repository.
- Build the project using the provided 'makefile' and run:
make demo
- run using./demo
(simple test)make test
- run using./test
(advanced doctest)make tidy
- makes sure the code is cleanmake valgrind
- makes sure there are no memory leaks/problems.
If you want to use the implemented functions by yourself, see the demo.cpp
file for run exmaples.
The personal_test
folder includes the file visualize_graph.py
, which can be used to visualize graphs and write good tests for them. This Python script complements the C++ implementations by providing a visualization tool.
Example for graph3 in demo.cpp
: