This Java program is to check whether graph is bipartite using bfs. In the mathematical field of graph theory, a bipartite graph (or bigraph) is a graph whose vertices can be divided into two disjoint sets and such that every edge connects a vertex in to one in that is, and are each independent sets. Equivalently, a bipartite graph is a graph that does not contain any odd-length cycles.
Here is the source code of the Java program to check whether a graph is biparite using bfs. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
import java.util.InputMismatchException;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;
public class BipartiteBfs
{
private int numberOfVertices;
private Queue<Integer> queue;
public static final int NO_COLOR = 0;
public static final int RED = 1;
public static final int BLUE = 2;
public BipartiteBfs(int numberOfVertices)
{
this.numberOfVertices = numberOfVertices;
queue = new LinkedList<Integer>();
}
public boolean isBipartite(int adjacencyMatrix[][], int source)
{
int[] colored = new int[numberOfVertices + 1];
for (int vertex = 1; vertex <= numberOfVertices; vertex++)
{
colored[vertex] = NO_COLOR;
}
colored = RED;
queue.add(source);
int element, neighbour;
while (!queue.isEmpty())
{
element = queue.remove();
neighbour = 1;
while (neighbour <= numberOfVertices)
{
if (adjacencyMatrix[element][neighbour] == 1 && colored[element]== colored[neighbour])
{
return false;
}
if (adjacencyMatrix[element][neighbour] == 1 && colored[neighbour]== NO_COLOR)
{
colored[neighbour] = (colored[element] == RED ) ? BLUE :RED;
queue.add(neighbour);
}
neighbour++;
}
}
return true;
}
public static void main(String... arg)
{
int number_of_nodes, source;
Scanner scanner = null;
try
{
System.out.println("Enter the number of nodes in the graph");
scanner = new Scanner(System.in);
number_of_nodes = scanner.nextInt();
int adjacency_matrix[][] = new int[number_of_nodes + 1][number_of_nodes + 1];
System.out.println("Enter the adjacency matrix");
for (int i = 1; i <= number_of_nodes; i++)
{
for (int j = 1; j <= number_of_nodes; j++)
{
adjacency_matrix[i][j] = scanner.nextInt();
}
}
for (int i = 1; i <= number_of_nodes; i++)
{
for (int j = 1; j <= number_of_nodes; j++)
{
if(adjacency_matrix[i][j] == 1 && adjacency_matrix[j][i] == 0)
{
adjacency_matrix[j][i] = 1;
}
}
}
System.out.println("Enter the source for the graph");
source = scanner.nextInt();
BipartiteBfs bipartiteBfs = new BipartiteBfs(number_of_nodes);
if (bipartiteBfs.isBipartite(adjacency_matrix, source))
{
System.out.println("The given graph is bipartite");
} else
{
System.out.println("The given graph is not bipartite");
}
} catch (InputMismatchException inputMismatch)
{
System.out.println("Wrong Input format");
}
scanner.close();
}
}
$javac BipartiteBfs.java $java BipartiteBfs Enter the number of nodes in the graph 4 Enter the adjacency matrix 0 1 0 1 1 0 1 0 0 1 0 1 1 0 1 0 Enter the source for the graph 1 The given graph is bipartite
Related posts:
Introduction to Apache Commons Text
Spring Boot - Build Systems
Java Program to add two large numbers using Linked List
Spring Cloud AWS – S3
Guide to the Java TransferQueue
Java Program to Implement Segment Tree
Java Program to Perform integer Partition for a Specific Case
Java – Create a File
Java Program to Find the Peak Element of an Array O(n) time (Naive Method)
Java Program to Implement Find all Cross Edges in a Graph
Một số tính năng mới về xử lý ngoại lệ trong Java 7
Loại bỏ các phần tử trùng trong một ArrayList như thế nào?
Java Program to Implement a Binary Search Algorithm for a Specific Search Sequence
Spring RequestMapping
Java Program to Find the Mode in a Data Set
Hướng dẫn Java Design Pattern – Transfer Object
Apache Commons Collections OrderedMap
Assert an Exception is Thrown in JUnit 4 and 5
Hướng dẫn Java Design Pattern – Adapter
Introduction to Spring Security Expressions
Java Program to Use Boruvka’s Algorithm to Find the Minimum Spanning Tree
Java Program to Implement LinkedBlockingQueue API
Java Program to Implement TreeMap API
ExecutorService – Waiting for Threads to Finish
REST Web service: Basic Authentication trong Jersey 2.x
Functional Interface trong Java 8
Java Program to Implement SimpeBindings API
Apache Commons Collections MapUtils
Java Program to Perform Finite State Automaton based Search
An Introduction to Java.util.Hashtable Class
Java Program to Test Using DFS Whether a Directed Graph is Strongly Connected or Not
Object Type Casting in Java