This is a Java Program to Check for balanced parenthesis by using Stacks. Parenthesis matching is commonly used for evaluating arithmetic expressions and in editors for validating syntax.
Here is the source code of the Java Program to check for balanced parenthesis by using stacks. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/*
* Java Program to Check for balanced paranthesis by using Stacks
*/
import java.util.*;
public class ParenthesisMatching
{
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
/* Creating Stack */
Stack<Integer> stk = new Stack<Integer>();
System.out.println("Parenthesis Matching Test\n");
/* Accepting expression */
System.out.println("Enter expression");
String exp = scan.next();
int len = exp.length();
System.out.println("\nMatches and Mismatches:\n");
for (int i = 0; i < len; i++)
{
char ch = exp.charAt(i);
if (ch == '(')
stk.push(i);
else if (ch == ')')
{
try
{
int p = stk.pop() + 1;
System.out.println("')' at index "+(i+1)+" matched with ')' at index "+p);
}
catch(Exception e)
{
System.out.println("')' at index "+(i+1)+" is unmatched");
}
}
}
while (!stk.isEmpty() )
System.out.println("'(' at index "+(stk.pop() +1)+" is unmatched");
}
}
Parenthesis Matching Test
Enter expression
(a+(b*c)-d)
Matches and Mismatches:
')' at index 8 matched with ')' at index 4
')' at index 11 matched with ')' at index 1
Parenthesis Matching Test
Enter expression
((x+y/(z-w))
Matches and Mismatches:
')' at index 11 matched with ')' at index 7
')' at index 12 matched with ')' at index 2
'(' at index 1 is unmatched
Parenthesis Matching Test
Enter expression
(a+b*(c-d)-(e-f/(g+h*(k-i)/(l-j+k
Matches and Mismatches:
')' at index 10 matched with ')' at index 6
')' at index 26 matched with ')' at index 22
'(' at index 28 is unmatched
'(' at index 17 is unmatched
'(' at index 12 is unmatched
'(' at index 1 is unmatched
Related posts:
Java Program to Implement Sorted Array
Mapping a Dynamic JSON Object with Jackson
Jackson Annotation Examples
Java Program to Represent Linear Equations in Matrix Form
Java Program to Implement Hash Tables with Quadratic Probing
Java Program to Implement the Alexander Bogomolny’s UnOrdered Permutation Algorithm for Elements Fro...
New Features in Java 14
Java Program to Implement Self Balancing Binary Search Tree
Spring Boot - Logging
Calling Stored Procedures from Spring Data JPA Repositories
Java Program to Find Nearest Neighbor Using Linear Search
Java Program to Implement Hash Tables Chaining with List Heads
JWT – Token-based Authentication trong Jersey 2.x
Java Program to Implement Sorted Vector
Java Program to Implement SimpeBindings API
Spring Data JPA @Query
Java Streams vs Vavr Streams
Java Program to Check if any Graph is Possible to be Constructed for a Given Degree Sequence
Spring Boot - Web Socket
How to Read a File in Java
Java Program to Implement Interpolation Search Algorithm
HttpClient with SSL
Java Program to Solve Tower of Hanoi Problem using Stacks
Lớp Arrarys trong Java (Arrays Utility Class)
Java Program to Give an Implementation of the Traditional Chinese Postman Problem
How to Convert List to Map in Java
Java Program to Implement Triply Linked List
REST Web service: Basic Authentication trong Jersey 2.x
Java Program to Perform Cryptography Using Transposition Technique
Java Program to Implement Binomial Heap
Spring Data JPA Delete and Relationships
Merging Streams in Java