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 ArrayDeque API
Java Program to Implement Sorted Array
Mảng (Array) trong Java
Introduction to Eclipse Collections
Jackson Date
Spring Boot - Sending Email
Cachable Static Assets with Spring MVC
Java Program to Check Cycle in a Graph using Topological Sort
Java Program to Implement Ternary Heap
Spring Data MongoDB – Indexes, Annotations and Converters
Java Program to Implement PrinterStateReasons API
Pagination and Sorting using Spring Data JPA
Custom Cascading in Spring Data MongoDB
Custom HTTP Header with the HttpClient
Java Program to Compute Cross Product of Two Vectors
Tạo ứng dụng Java RESTful Client với thư viện OkHttp
Java Scanner hasNext() vs. hasNextLine()
A Guide to HashSet in Java
A Comparison Between Spring and Spring Boot
Java Program to Solve Tower of Hanoi Problem using Stacks
Java Program to Implement Quick Sort with Given Complexity Constraint
Functional Interface trong Java 8
Checking for Empty or Blank Strings in Java
Converting Between an Array and a Set in Java
Guide to the Java ArrayList
Spring Data JPA Delete and Relationships
“Stream has already been operated upon or closed” Exception in Java
Set Interface trong Java
Converting Strings to Enums in Java
Using JWT with Spring Security OAuth (legacy stack)
Java Program to Implement Counting Sort
Java Program to Compute Discrete Fourier Transform Using Naive Approach