This Java program is to implement graph structured stack. In computer science, a graph-structured stack is a directed acyclic graph where each directed path represents a stack. The graph-structured stack is an essential part of Tomita’s algorithm, where it replaces the usual stack of a pushdown automaton. This allows the algorithm to encode the nondeterministic choices in parsing an ambiguous grammar, sometimes with greater efficiency.
Here is the source code of the Java program to implement graph structured stack. The Java program is successfully compiled and run on a Linux system. The program output is also shown below.
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Scanner;
import java.util.Stack;
public class GraphStructuredStack
{
private ArrayList<Stack<Integer>> stackList;
private Stack<Integer> stack;
private int numberOfNodes;
private int adjacencyMatrix[][];
private int[] parent;
public GraphStructuredStack()
{
stackList = new ArrayList<Stack<Integer>>();
stack = new Stack<Integer>();
}
public void graphStructuredStack(int adjacencyMatrix[][],int source,int bottomNode)
{
boolean stackFound = false;
this.numberOfNodes = adjacencyMatrix.length - 1;
this.adjacencyMatrix = new int[numberOfNodes + 1][numberOfNodes +1];
this.parent = new int[numberOfNodes+ 1];
for (int sourceVertex = 1; sourceVertex <= numberOfNodes; sourceVertex++)
{
for (int destinationVertex = 1; destinationVertex <= numberOfNodes; destinationVertex++)
{
this.adjacencyMatrix[sourceVertex][destinationVertex]
= adjacencyMatrix[sourceVertex][destinationVertex];
}
}
stack.push(source);
int element, destination;
while (!stack.isEmpty())
{
element = stack.peek();
destination = 1;
while (destination <= numberOfNodes)
{
if (this.adjacencyMatrix[element][destination] == 1)
{
stack.push(destination);
parent[destination] = element;
this.adjacencyMatrix[element][destination] = 0;
if (destination == bottomNode)
{
stackFound = true;
break;
}
element = destination;
destination = 1;
continue;
}
destination++;
}
if (stackFound)
{
Stack<Integer> istack = new Stack<Integer>();
for (int node = bottomNode; node != source; node = parent[node])
{
istack.push(node);
}
istack.push(source);
stackList.add(istack);
stackFound = false;
}
stack.pop();
}
Iterator<Stack<Integer>> iterator = stackList.iterator();
while (iterator.hasNext())
{
Stack<Integer> stack = iterator.next();
Iterator<Integer> stckitr = stack.iterator();
while (stckitr.hasNext())
{
System.out.print(stckitr.next() +"\t");
}
System.out.println();
}
}
public static void main(String...arg)
{
int adjacencyMatrix[][];
int numberofnodes;
int source, bottom;
Scanner scanner = new Scanner(System.in);
System.out.println("enter the number of nodes");
numberofnodes = scanner.nextInt();
adjacencyMatrix = new int[numberofnodes + 1] [numberofnodes + 1];
System.out.println("enter the graph matrix");
for (int sourceVertex = 1; sourceVertex <= numberofnodes; sourceVertex++)
{
for (int destinationVertex = 1; destinationVertex <= numberofnodes; destinationVertex++)
{
adjacencyMatrix[sourceVertex][destinationVertex] = scanner.nextInt();
}
}
System.out.println("enter the source node");
source = scanner.nextInt();
System.out.println("enter the bottom node");
bottom = scanner.nextInt();
System.out.println("the stacks are");
GraphStructuredStack graphStructuredStack = new GraphStructuredStack();
graphStructuredStack.graphStructuredStack(adjacencyMatrix, source, bottom);
scanner.close();
}
}
$javac GraphStructuredStack.java $java GraphStructuredStack enter the number of nodes 6 enter the graph matrix 0 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 0 1 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 enter the source node 6 enter the bottom node 1 the stacks are 1 2 4 5 6 1 3 4 5 6
Related posts:
Java Program to Implement the linear congruential generator for Pseudo Random Number Generation
Java Program to Implement Affine Cipher
Converting a Stack Trace to a String in Java
Java Program to Implement Gabow Algorithm
Java Program to Check Whether a Given Point is in a Given Polygon
Java Program to Implement ArrayList API
Java Program to Generate a Random UnDirected Graph for a Given Number of Edges
The Order of Tests in JUnit
Java Program to Implement Sorted Circular Doubly Linked List
Java Program to Implement TreeMap API
A Guide to HashSet in Java
Tìm hiểu về Web Service
The Thread.join() Method in Java
Sao chép các phần tử của một mảng sang mảng khác như thế nào?
Java Program to Find Nearest Neighbor for Dynamic Data Set
Java Program to Check if a Given Binary Tree is an AVL Tree or Not
Lớp Collectors trong Java 8
Spring Boot with Multiple SQL Import Files
Java Program to Generate All Possible Subsets with Exactly k Elements in Each Subset
Spring Boot - Bootstrapping
Java Program to Implement Ternary Heap
A Guide to JUnit 5
Java Program to Implement Sieve Of Sundaram
Transaction Propagation and Isolation in Spring @Transactional
Java Program to Implement Euler Circuit Problem
Constructor Injection in Spring with Lombok
Spring Security Custom AuthenticationFailureHandler
Exploring the Spring Boot TestRestTemplate
Guide to ThreadLocalRandom in Java
Serverless Functions with Spring Cloud Function
Extract network card address
Iterating over Enum Values in Java