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 Solve the Fractional Knapsack Problem
Java Program to Find Strongly Connected Components in Graphs
Guide to CopyOnWriteArrayList
Java Program to Implement Suffix Array
Transaction Propagation and Isolation in Spring @Transactional
Properties with Spring and Spring Boot
Immutable ArrayList in Java
Java Program to Implement Cubic convergence 1/pi Algorithm
Java Program to Implement LinkedHashSet API
Java String to InputStream
Java Program to Find MST (Minimum Spanning Tree) using Kruskal’s Algorithm
Quick Guide on Loading Initial Data with Spring Boot
Hướng dẫn Java Design Pattern – Factory Method
Java Deep Learning Essentials - Yusuke Sugomori
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
Java Program to Implement Adjacency Matrix
Sorting Query Results with Spring Data
Java Program to Implement Double Ended Queue
Java Program to Implement Binomial Tree
Spring Boot Annotations
Hướng dẫn Java Design Pattern – Observer
Spring MVC Tutorial
Get the workstation name or IP
Partition a List in Java
Các nguyên lý thiết kế hướng đối tượng – SOLID
Java Program to Generate All Possible Combinations of a Given List of Numbers
Java Program to Implement Booth Algorithm
Exploring the Spring 5 WebFlux URL Matching
Java Program to Implement Knapsack Algorithm
How to Get the Last Element of a Stream in Java?
Spring Boot - Admin Server
Chương trình Java đầu tiên