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:
Deploy a Spring Boot App to Azure
Java Program to Show the Duality Transformation of Line and Point
Spring Boot Annotations
A Guide to Spring Boot Admin
Java Program to Check Whether a Given Point is in a Given Polygon
HttpClient Basic Authentication
Spring Boot - Logging
Extract links from an HTML page
DistinctBy in the Java Stream API
Get and Post Lists of Objects with RestTemplate
Spring @Primary Annotation
Hướng dẫn Java Design Pattern – Decorator
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Java Program to Find the Nearest Neighbor Using K-D Tree Search
Registration – Password Strength and Rules
Spring Boot: Customize Whitelabel Error Page
Unsatisfied Dependency in Spring
Java Deep Learning Essentials - Yusuke Sugomori
Display Auto-Configuration Report in Spring Boot
Java Program to Implement TreeMap API
Java Program to Implement ConcurrentSkipListMap API
Guide to Apache Commons CircularFifoQueue
Java Program to Find MST (Minimum Spanning Tree) using Prim’s Algorithm
Java Program to Implement Quick Sort Using Randomization
Reactive Flow with MongoDB, Kotlin, and Spring WebFlux
Java Program to Find Minimum Element in an Array using Linear Search
Registration with Spring Security – Password Encoding
Optional trong Java 8
Collect a Java Stream to an Immutable Collection
Reversing a Linked List in Java
Mix plain text and HTML content in a mail
Performance Difference Between save() and saveAll() in Spring Data