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 Solve Set Cover Problem assuming at max 2 Elements in a Subset
Spring 5 WebClient
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
Spring Boot - Enabling HTTPS
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
XML Serialization and Deserialization with Jackson
A Guide to Java HashMap
REST Web service: Upload và Download file với Jersey 2.x
Using Spring @ResponseStatus to Set HTTP Status Code
Converting Between Byte Arrays and Hexadecimal Strings in Java
The Thread.join() Method in Java
Java Program to Solve Knapsack Problem Using Dynamic Programming
Debugging Reactive Streams in Java
Disable Spring Data Auto Configuration
Java Program to Implement Gaussian Elimination Algorithm
Tạo chương trình Java đầu tiên sử dụng Eclipse
Java Program to Implement Cubic convergence 1/pi Algorithm
Spring Boot - Cloud Configuration Server
Entity To DTO Conversion for a Spring REST API
Java Program to Represent Graph Using 2D Arrays
Spring Data – CrudRepository save() Method
Multipart Upload with HttpClient 4
REST Pagination in Spring
Java Program to Find the Vertex Connectivity of a Graph
Java Program to Emulate N Dice Roller
A Quick Guide to Spring MVC Matrix Variables
Apache Commons Collections MapUtils
Removing all Nulls from a List in Java
An Example of Load Balancing with Zuul and Eureka
The StackOverflowError in Java
The Dining Philosophers Problem in Java
Using a Mutex Object in Java