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:
Add Multiple Items to an Java ArrayList
Biến trong java
Array to String Conversions
Java Program to Generate All Subsets of a Given Set in the Lexico Graphic Order
Consumer trong Java 8
Spring MVC and the @ModelAttribute Annotation
Java Program to Encode a Message Using Playfair Cipher
Java Program to Solve a Matching Problem for a Given Specific Case
Hướng dẫn Java Design Pattern – MVC
Spring REST API + OAuth2 + Angular
Reactive Flow with MongoDB, Kotlin, and Spring WebFlux
Tổng quan về ngôn ngữ lập trình java
Spring Security Logout
Java – File to Reader
Hướng dẫn Java Design Pattern – Chain of Responsibility
Java Program to Find Minimum Number of Edges to Cut to make the Graph Disconnected
Java IO vs NIO
Từ khóa this và super trong Java
Java Program to Implement RoleList API
HttpClient 4 – Follow Redirects for POST
Hướng dẫn Java Design Pattern – Memento
A Guide to the Java LinkedList
Mix plain text and HTML content in a mail
Reversing a Linked List in Java
Java Program to Sort an Array of 10 Elements Using Heap Sort Algorithm
Java Program to implement Sparse Vector
A Guide to JUnit 5
HandlerAdapters in Spring MVC
Java 8 Streams peek() API
Server-Sent Events in Spring
Converting a List to String in Java
Java Program to Implement LinkedBlockingDeque API