This is a java program to create a random linear extension of DAG. Linear extension of DAG is nothing but topological sorting in simple terms.
Here is the source code of the Java Program to Create a Random Linear Extension for a DAG. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.maixuanviet.graph;
import java.util.InputMismatchException;
import java.util.Scanner;
import java.util.Stack;
public class DAGLinearExtension
{
private Stack<Integer> stack;
public DAGLinearExtension()
{
stack = new Stack<Integer>();
}
public int[] topological(int adjacency_matrix[][], int source)
throws NullPointerException
{
int number_of_nodes = adjacency_matrix.length - 1;
int[] topological_sort = new int[number_of_nodes + 1];
int pos = 1;
int j;
int visited[] = new int[number_of_nodes + 1];
int element = source;
int i = source;
visited = 1;
stack.push(source);
while (!stack.isEmpty())
{
element = stack.peek();
while (i <= number_of_nodes)
{
if (adjacency_matrix[element][i] == 1 && visited[i] == 1)
{
if (stack.contains(i))
{
System.out.println("TOPOLOGICAL SORT NOT POSSIBLE");
return null;
}
}
if (adjacency_matrix[element][i] == 1 && visited[i] == 0)
{
stack.push(i);
visited[i] = 1;
element = i;
i = 1;
continue;
}
i++;
}
j = stack.pop();
topological_sort[pos++] = j;
i = ++j;
}
return topological_sort;
}
public static void main(String... arg)
{
int number_no_nodes, source;
Scanner scanner = null;
int topological_sort[] = null;
System.out
.println("Linear extension of a DAG is its topological reperesentation.");
try
{
System.out.println("Enter the number of nodes in the graph");
scanner = new Scanner(System.in);
number_no_nodes = scanner.nextInt();
int adjacency_matrix[][] = new int[number_no_nodes + 1][number_no_nodes + 1];
System.out.println("Enter the adjacency matrix");
for (int i = 1; i <= number_no_nodes; i++)
for (int j = 1; j <= number_no_nodes; j++)
adjacency_matrix[i][j] = scanner.nextInt();
System.out.println("Enter the source for the graph");
source = scanner.nextInt();
System.out
.println("The Topological sort for the graph is given by ");
DAGLinearExtension toposort = new DAGLinearExtension();
topological_sort = toposort.topological(adjacency_matrix, source);
for (int i = topological_sort.length - 1; i > 0; i--)
{
if (topological_sort[i] != 0)
System.out.print(topological_sort[i] + "\t");
}
}
catch (InputMismatchException inputMismatch)
{
System.out.println("Wrong Input format");
}
catch (NullPointerException nullPointer)
{
}
scanner.close();
}
}
Output:
$ javac DAGLinearExtension.java $ java DAGLinearExtension Linear extension of a DAG is its topological reperesentation. Enter the number of nodes in the graph 6 Enter the adjacency matrix 0 1 0 0 0 1 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 1 0 0 0 Enter the source for the graph 1 The Topological sort for the graph is given by 1 2 4 5 6 3
Related posts:
Java Program to Check whether Graph is Biconnected
A Guide to Java HashMap
Extract network card address
Weak References in Java
Jackson – Marshall String to JsonNode
Java 8 Predicate Chain
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Java Program to Sort an Array of 10 Elements Using Heap Sort Algorithm
Generating Random Dates in Java
“Stream has already been operated upon or closed” Exception in Java
Introduction to Using Thymeleaf in Spring
Java Program to Perform Naive String Matching
Java Program to Perform Complex Number Multiplication
Inject Parameters into JUnit Jupiter Unit Tests
Inheritance with Jackson
Java Program to Implement Iterative Deepening
Giới thiệu Google Guice – Dependency injection (DI) framework
Converting String to Stream of chars
Testing in Spring Boot
Java Program to Implement Adjacency List
Java Program to Check whether Directed Graph is Connected using BFS
Introduction to Eclipse Collections
Lớp HashMap trong Java
Java Program to Implement Insertion Sort
Java Program to Construct a Random Graph by the Method of Random Edge Selection
Java Program to Perform Right Rotation on a Binary Search Tree
Giới thiệu JDBC Connection Pool
Java Program to Implement Hash Tables Chaining with Doubly Linked Lists
Hướng dẫn Java Design Pattern – Singleton
Java Program to Implement Borwein Algorithm
The Spring @Controller and @RestController Annotations
Java Program to Perform the Unique Factorization of a Given Number