From a1eff4fc8b6ebd7f9d7c93fcf90d45d6a2213e64 Mon Sep 17 00:00:00 2001 From: Helena He <73536278+helarious99@users.noreply.github.com> Date: Tue, 1 Mar 2022 08:01:18 -0500 Subject: [PATCH] chore(CPlusPlus): add cycle detection (#686) --- .../CPlusPlus/Graphs/cycle-detection.cpp | 87 +++++++++++++++++++ algorithms/CPlusPlus/README.md | 1 + 2 files changed, 88 insertions(+) create mode 100644 algorithms/CPlusPlus/Graphs/cycle-detection.cpp diff --git a/algorithms/CPlusPlus/Graphs/cycle-detection.cpp b/algorithms/CPlusPlus/Graphs/cycle-detection.cpp new file mode 100644 index 00000000..946cc551 --- /dev/null +++ b/algorithms/CPlusPlus/Graphs/cycle-detection.cpp @@ -0,0 +1,87 @@ +// Program to detect whether a graph contains a cycle. The vertices of the graph are +// placed in disjoint sets. As each edge is iterated through, the subset of the two +// vertices is determined. If the subsets are the same, then a cycle is found. +// Otherwise, the algorithm will join the two subsets together and repeat the process +// until each edge is iterated through or a cycle is found. +#include +#include +#include +#include +#include + +// Edge list implementation of unweighted, undirected graph +class Graph +{ + private: + std::vector> edgeList; + std::unordered_set uniqueVertices; // Keep track of the number of unique vertices + + public: + void insertEdge(int from, int to); + bool isCycle(); + int findSet(std::vector& parent, int i); + void unionSet(std::vector& parent, int x, int y); +}; + +void Graph::insertEdge(int from, int to) +{ + edgeList.push_back(std::make_pair(from, to)); + uniqueVertices.insert(from); + uniqueVertices.insert(to); +} + +bool Graph::isCycle() +{ + // Initialize parent vector as disjoint sets + std::vector parent(uniqueVertices.size(), -1); + + // Iterate through all graph edges + for (auto i : edgeList) + { + // Find the subset of both vertices of an edge + int x = findSet(parent, i.first); + int y = findSet(parent, i.second); + + // If the subsets are the same, then there is a cycle in the graph + if (x == y) + { + return true; + } + + unionSet(parent, x, y); + } + + return false; +} + +int Graph::findSet(std::vector& parent, int i) +{ + if (parent[i] == -1) + { + return i; + } + return findSet(parent, parent[i]); +} + +void Graph::unionSet(std::vector& parent, int x, int y) +{ + parent[x] = y; +} + +// Sample test case +// Time complexity is O(E) where E is the number of edges +int main() +{ + Graph graph; + graph.insertEdge(0, 1); + graph.insertEdge(0, 2); + graph.insertEdge(1, 2); + if (graph.isCycle()) + { + std::cout << "Graph contains a cycle" << std::endl; + } + else{ + std::cout << "Graph does not contain a cycle" << std::endl; + } + return 0; +} diff --git a/algorithms/CPlusPlus/README.md b/algorithms/CPlusPlus/README.md index 314e0019..049f2374 100644 --- a/algorithms/CPlusPlus/README.md +++ b/algorithms/CPlusPlus/README.md @@ -50,6 +50,7 @@ - [Dfs traversal with recursion](Graphs/dfs-traversal.cpp) - [Connected Components](Graphs/total-connected-components.cpp) - [Dijkstra's Algorithm](Graphs/dijkstra.cpp) +- [Cycle Detection](Graphs/cycle-detection.cpp) ## Multiplication