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:
Generate Spring Boot REST Client with Swagger
Java Program to Generate All Subsets of a Given Set in the Gray Code Order
Java Program to Implement the MD5 Algorithm
Test a REST API with Java
Using a Spring Cloud App Starter
Java Program to Implement wheel Sieve to Generate Prime Numbers Between Given Range
Spring 5 WebClient
Java Program to Implement Disjoint Set Data Structure
Inheritance and Composition (Is-a vs Has-a relationship) in Java
Giới thiệu Aspect Oriented Programming (AOP)
The Java 8 Stream API Tutorial
Java Program to Implement Sieve Of Sundaram
Upload and Display Excel Files with Spring MVC
A Guide to Java SynchronousQueue
Create Java Applet to Simulate Any Sorting Technique
Java Program to Implement Borwein Algorithm
Injecting Prototype Beans into a Singleton Instance in Spring
Service Registration with Eureka
Java – Reader to InputStream
So sánh HashMap và Hashtable trong Java
Java Program to Implement Rolling Hash
Java 14 Record Keyword
Converting String to Stream of chars
Partition a List in Java
Hướng dẫn sử dụng Lớp FilePermission trong java
Introduction to Using FreeMarker in Spring MVC
Java Program to Check Cycle in a Graph using Topological Sort
Introduction to Spring Data REST
HttpClient Timeout
Java Program to Implement Suffix Tree
Using Custom Banners in Spring Boot
Java Program to Find a Good Feedback Edge Set in a Graph