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 – Combine Multiple Collections
Java Program to Check if a Given Graph Contain Hamiltonian Cycle or Not
Converting Between an Array and a Set in Java
Java – Random Long, Float, Integer and Double
Java Program to Implement First Fit Decreasing for 1-D Objects and M Bins
The Registration API becomes RESTful
Most commonly used String methods in Java
Giới thiệu Json Web Token (JWT)
Java Program to Implement Segment Tree
Debugging Reactive Streams in Java
Java Optional as Return Type
Spring Security Login Page with React
Java Program to Implement ConcurrentSkipListMap API
Java Program to Represent Graph Using Incidence List
Tạo ứng dụng Java RESTful Client với thư viện Retrofit
Reading an HTTP Response Body as a String in Java
Java Program to Implement Hopcroft Algorithm
Java Program to Implement Adjacency Matrix
Logging in Spring Boot
Spring Cloud AWS – S3
Introduction to Spring Cloud Rest Client with Netflix Ribbon
Java Program to Generate Random Hexadecimal Byte
Java Program to Implement CopyOnWriteArrayList API
Apache Commons Collections SetUtils
Uploading MultipartFile with Spring RestTemplate
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Autoboxing và Unboxing trong Java
Guide to Spring @Autowired
Java Program to Find Basis and Dimension of a Matrix
Java Program to Perform Stooge Sort
Hướng dẫn kết nối cơ sở dữ liệu với Java JDBC
Summing Numbers with Java Streams