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:
Collect a Java Stream to an Immutable Collection
Immutable Objects in Java
Reactive Flow with MongoDB, Kotlin, and Spring WebFlux
Java Program to Implement Ternary Heap
A Guide to the ViewResolver in Spring MVC
Registration – Activate a New Account by Email
Apache Commons Collections BidiMap
Guide to the Fork/Join Framework in Java
The Spring @Controller and @RestController Annotations
Array to String Conversions
Tìm hiểu về Web Service
Documenting a Spring REST API Using OpenAPI 3.0
Java Program to Implement LinkedBlockingDeque API
Calling Stored Procedures from Spring Data JPA Repositories
Java 9 Stream API Improvements
So sánh ArrayList và Vector trong Java
Java Program to Implement Affine Cipher
How to Delay Code Execution in Java
Java Program to Implement Quick sort
Spring Boot - CORS Support
Inheritance and Composition (Is-a vs Has-a relationship) in Java
Java Program to Implement Range Tree
Spring Security Logout
Java Program to implement Sparse Vector
Receive email using POP3
Java Web Services – JAX-WS – SOAP
Java – Rename or Move a File
Refactoring Design Pattern với tính năng mới trong Java 8
Java Program to Use Boruvka’s Algorithm to Find the Minimum Spanning Tree
OAuth2 for a Spring REST API – Handle the Refresh Token in Angular
Spring Security Form Login
Write/Read cookies using HTTP and Read a file from the internet