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:
Spring WebClient vs. RestTemplate
A Guide to @RepeatedTest in Junit 5
Spring Boot - Sending Email
Sending Emails with Java
A Guide to Java 9 Modularity
Java Program to Generate All Subsets of a Given Set in the Gray Code Order
Java Program to Solve Set Cover Problem assuming at max 2 Elements in a Subset
String Initialization in Java
The Registration API becomes RESTful
Send an email with an attachment
Deploy a Spring Boot App to Azure
Spring MVC Tutorial
An Intro to Spring Cloud Zookeeper
Transactions with Spring and JPA
So sánh HashMap và Hashtable trong Java
Life Cycle of a Thread in Java
Java Program to Implement Quick Sort Using Randomization
Intro to Spring Boot Starters
Java Program to Implement HashTable API
Java Program to implement Sparse Vector
Loại bỏ các phần tử trùng trong một ArrayList như thế nào?
JUnit 5 for Kotlin Developers
The Basics of Java Security
Java Program to Compute the Area of a Triangle Using Determinants
Luồng Daemon (Daemon Thread) trong Java
Introduction to Spring Data JPA
Remove the First Element from a List
Java Program for Topological Sorting in Graphs
How to Use if/else Logic in Java 8 Streams
Mapping Nested Values with Jackson
Calling Stored Procedures from Spring Data JPA Repositories
Java Program to Implement Quick sort