This is a Java Program to Implement Graph Coloring Algorithm. Graph Coloring is a way of coloring the vertices of a undirected graph such that no two adjacent vertices share the same color.
Here is the source code of the Java Program to Implement Graph Coloring Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
** Java Program to Implement Graph Coloring Algorithm
**/
import java.util.Scanner;
/** Class GraphColoring **/
public class GraphColoring
{
private int V, numOfColors;
private int[] color;
private int[][] graph;
/** Function to assign color **/
public void graphColor(int[][] g, int noc)
{
V = g.length;
numOfColors = noc;
color = new int[V];
graph = g;
try
{
solve(0);
System.out.println("No solution");
}
catch (Exception e)
{
System.out.println("\nSolution exists ");
display();
}
}
/** function to assign colors recursively **/
public void solve(int v) throws Exception
{
/** base case - solution found **/
if (v == V)
throw new Exception("Solution found");
/** try all colours **/
for (int c = 1; c <= numOfColors; c++)
{
if (isPossible(v, c))
{
/** assign and proceed with next vertex **/
color[v] = c;
solve(v + 1);
/** wrong assignement **/
color[v] = 0;
}
}
}
/** function to check if it is valid to allot that color to vertex **/
public boolean isPossible(int v, int c)
{
for (int i = 0; i < V; i++)
if (graph[v][i] == 1 && c == color[i])
return false;
return true;
}
/** display solution **/
public void display()
{
System.out.print("\nColors : ");
for (int i = 0; i < V; i++)
System.out.print(color[i] +" ");
System.out.println();
}
/** Main function **/
public static void main (String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Graph Coloring Algorithm Test\n");
/** Make an object of GraphColoring class **/
GraphColoring gc = new GraphColoring();
/** Accept number of vertices **/
System.out.println("Enter number of verticesz\n");
int V = scan.nextInt();
/** get graph **/
System.out.println("\nEnter matrix\n");
int[][] graph = new int[V][V];
for (int i = 0; i < V; i++)
for (int j = 0; j < V; j++)
graph[i][j] = scan.nextInt();
System.out.println("\nEnter number of colors");
int c = scan.nextInt();
gc.graphColor(graph, c);
}
}
Graph Coloring Algorithm Test Enter number of vertices 10 Enter matrix 0 1 0 0 0 1 0 0 0 0 1 0 1 0 0 0 1 0 0 0 0 1 0 1 0 0 0 1 0 0 0 0 1 0 1 0 0 0 1 0 1 0 0 1 0 0 0 0 0 1 1 0 0 0 0 0 0 1 1 0 0 1 0 0 0 0 0 0 1 1 0 0 1 0 0 1 0 0 0 1 0 0 0 1 0 1 1 0 0 0 0 0 0 0 1 0 1 1 0 0 Enter number of colors 3 Solution exists Colors : 1 2 1 2 3 2 1 3 3 2
Related posts:
Logout in an OAuth Secured Application
Java Program to Check whether Graph is a Bipartite using BFS
Java Convenience Factory Methods for Collections
Giới thiệu Swagger – Công cụ document cho RESTfull APIs
How to Manually Authenticate User with Spring Security
Java Program to Generate Random Numbers Using Middle Square Method
Toán tử trong java
Java Program to Implement Stack API
Java Program to Find ith Largest Number from a Given List Using Order-Statistic Algorithm
Converting Between a List and a Set in Java
Mệnh đề Switch-case trong java
How to Set TLS Version in Apache HttpClient
Java Program to Implement Splay Tree
Check if there is mail waiting
Spring Data JPA and Null Parameters
Check If a File or Directory Exists in Java
Reading an HTTP Response Body as a String in Java
@Order in Spring
Sử dụng JDBC API thực thi câu lệnh truy vấn dữ liệu
Java Program to find the maximum subarray sum using Binary Search approach
CharSequence vs. String in Java
Reactive Flow with MongoDB, Kotlin, and Spring WebFlux
Java – Delete a File
Java Program to Compute the Area of a Triangle Using Determinants
Java Program to Construct an Expression Tree for an Infix Expression
SOAP Web service: Authentication trong JAX-WS
REST Pagination in Spring
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java
HttpClient 4 Cookbook
Java Program to Implement Min Heap
Vòng lặp for, while, do-while trong Java
Spring Boot - Servlet Filter