TheAlgorithms-C-Plus-Plus/graph/is_graph_bipartite.cpp

147 lines
3.9 KiB
C++
Raw Normal View History

2020-08-14 02:53:51 +08:00
/**
* @file is_graph_bipartite
*
2020-08-14 12:34:21 +08:00
* @brief Algorithm to check whether a graph is [bipartite](https://en.wikipedia.org/wiki/Bipartite_graph)
*
2020-08-14 02:53:51 +08:00
* @details
* A graph is a collection of nodes also called vertices and these vertices
* are connected by edges.A bipartite graph is a graph whose vertices can be
* divided into two disjoint and independent sets U and V such that every edge
* connects a vertex in U to one in V.
2020-08-14 04:13:57 +08:00
*
2020-08-14 02:53:51 +08:00
* The given Algorithm will determine whether the given graph is bipartite or not
2020-08-14 12:34:21 +08:00
*
*
2020-08-14 02:53:51 +08:00
* Example - Here is a graph g1 with 5 vertices and is bipartite
2020-08-14 12:34:21 +08:00
*
2020-08-14 02:53:51 +08:00
* 1 4
* / \ / \
* 2 3 5
*
* Example - Here is a graph G2 with 3 vertices and is not bipartite
2020-08-14 12:34:21 +08:00
*
2020-08-14 02:53:51 +08:00
* 1 --- 2
* \ /
* 3
*
* @author [Akshat Vaya](https://github.com/AkVaya)
*
*/
#include <iostream>
#include <vector>
#include <queue>
const int nax = 5e5 + 1;
/**
* Class for representing graph as an adjacency list.
*/
class graph {
private:
int n; /// size of the graph
2020-08-14 04:13:57 +08:00
std::vector<std::vector <int> > adj; /// adj stores the graph as an adjacency list
2020-08-14 02:53:51 +08:00
2020-08-14 04:13:57 +08:00
std::vector<int> side; ///stores the side of the vertex
2020-08-14 02:53:51 +08:00
public:
/**
* @brief Constructor that initializes the graph on creation
*/
graph(int size = nax){
n = size;
adj.resize(n);
side.resize(n,-1);
}
void addEdge(int u, int v); /// function to add edges to our graph
bool is_bipartite(); /// function to check whether the graph is bipartite or not
};
/**
* @brief Function that add an edge between two nodes or vertices of graph
*
* @param u is a node or vertex of graph
* @param v is a node or vertex of graph
*/
void graph::addEdge(int u, int v) {
adj[u-1].push_back(v-1);
adj[v-1].push_back(u-1);
}
/**
* @brief function that checks whether the graph is bipartite or not
2020-08-14 04:13:57 +08:00
* the function returns true if the graph is a bipartite graph
* the function returns false if the graph is not a bipartite graph
2020-08-14 12:34:21 +08:00
*
* @details
* Here, side refers to the two disjoint subsets of the bipartite graph.
* Initially, the values of side are set to -1 which is an unassigned state. A for loop is run for every vertex of the graph.
* If the current edge has no side assigned to it, then a Breadth First Search operation is performed.
* If two neighbours have the same side then the graph will not be bipartite and the value of check becomes false.
* If and only if each pair of neighbours have different sides, the value of check will be true and hence the graph bipartite.
*
2020-08-14 02:53:51 +08:00
*/
bool graph::is_bipartite(){
bool check = true;
2020-08-14 04:13:57 +08:00
std::queue<int> q;
2020-08-14 02:53:51 +08:00
for (int current_edge = 0; current_edge < n; ++current_edge)
{
if(side[current_edge] == -1){
q.push(current_edge);
side[current_edge] = 0;
while(q.size()){
int current = q.front();
q.pop();
for(auto neighbour : adj[current]){
if(side[neighbour] == -1){
side[neighbour] = (1 ^ side[current]);
q.push(neighbour);
}
else{
check &= (side[neighbour] != side[current]);
}
}
}
}
}
return check;
}
/**
2020-08-14 04:13:57 +08:00
* Function to test the above algorithm
2020-08-14 02:53:51 +08:00
*/
2020-08-14 04:13:57 +08:00
void test(){
2020-08-14 02:53:51 +08:00
graph G1(5); /// creating graph G1 with 5 vertices
/// adding edges to the graphs as per the illustrated example
G1.addEdge(1,2);
G1.addEdge(1,3);
G1.addEdge(3,4);
G1.addEdge(4,5);
graph G2(3); /// creating graph G2 with 3 vertices
/// adding edges to the graphs as per the illustrated example
G2.addEdge(1,2);
G2.addEdge(1,3);
G2.addEdge(2,3);
2020-08-14 04:13:57 +08:00
2020-08-14 02:53:51 +08:00
/// checking whether the graphs are bipartite or not
if(G1.is_bipartite()){
std::cout<<"The given graph G1 is a bipartite graph\n";
}
else{
std::cout<<"The given graph G1 is not a bipartite graph\n";
}
if(G2.is_bipartite()){
std::cout<<"The given graph G2 is a bipartite graph\n";
}
else{
std::cout<<"The given graph G2 is not a bipartite graph\n";
}
2020-08-14 04:13:57 +08:00
}
/**
* Main function
*/
int main(){
test(); ///Testing
2020-08-14 02:53:51 +08:00
return 0;
2020-08-14 03:36:24 +08:00
}