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:
Spring Boot Configuration with Jasypt
Java Program to Implement Bit Array
Giới thiệu Google Guice – Binding
ETags for REST with Spring
Java Program to Represent Graph Using Adjacency List
Vấn đề Nhà sản xuất (Producer) – Người tiêu dùng (Consumer) và đồng bộ hóa các luồng trong Java
New Stream Collectors in Java 9
A Guide to Java HashMap
Guide to Java 8’s Collectors
A Quick Guide to Using Keycloak with Spring Boot
Comparing Objects in Java
Java Program to Implement Queue using Linked List
Java Program to Generate All Possible Subsets with Exactly k Elements in Each Subset
DistinctBy in the Java Stream API
Checking for Empty or Blank Strings in Java
Một số nguyên tắc, định luật trong lập trình
Lập trình đa luồng với CompletableFuture trong Java 8
Java Program to Implement Leftist Heap
Adding Shutdown Hooks for JVM Applications
Spring Boot Annotations
Java Program to Compute the Area of a Triangle Using Determinants
Intro to Spring Boot Starters
Guide to Java 8 groupingBy Collector
Java Program to Find k Numbers Closest to Median of S, Where S is a Set of n Numbers
Java Program to Implement Park-Miller Random Number Generation Algorithm
Fixing 401s with CORS Preflights and Spring Security
Spring Boot - Code Structure
Lập trình mạng với java
Java Program to implement Bit Matrix
Spring Cloud – Securing Services
Entity To DTO Conversion for a Spring REST API
Java Program to Search for an Element in a Binary Search Tree