This is a Java Program to Implement Shunting Yard Algorithm. Shunting Yard algorithm is used for converting an infix expression into a postfix expression.
Here is the source code of the Java Program to Implement Shunting Yard Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/** ** Java Program to Implement Shunting Yard Algorithm **/ import java.util.Scanner; /** Class ShuntingYard **/ public class ShuntingYard { /** enum **/ private enum Precedence { lparen(0), rparen(1), plus(2), minus(3), divide(4), times(5), mod(6), eos(7), operand(8); private int index; Precedence(int index) { this.index = index; } public int getIndex() { return index; } } /** in stack precedence **/ private static final int[] isp = {0, 19, 12, 12, 13, 13, 13, 0}; /** incoming character precedence **/ private static final int[] icp = {20, 19, 12, 12, 13, 13, 13, 0}; /** operators **/ private static final char[] operators = {'{', '}', '+', '-', '/', '*', '%', ' '}; /** precedence stack **/ private Precedence[] stack; /** stack top pointer **/ private int top; /** pop element from stack **/ private Precedence pop() { return stack[top--]; } /** push element onto stack **/ private void push(Precedence ele) { stack[++top] = ele; } /** get precedence token for symbol **/ public Precedence getToken(char symbol) { switch (symbol) { case '(' : return Precedence.lparen; case ')' : return Precedence.rparen; case '+' : return Precedence.plus; case '-' : return Precedence.minus; case '/' : return Precedence.divide; case '*' : return Precedence.times; case '%' : return Precedence.mod; case ' ' : return Precedence.eos; default : return Precedence.operand; } } /** Function to convert infix to postfix **/ public String postfix(String infix) { String postfix = ""; top = 0; stack = new Precedence[infix.length()]; stack[0] = Precedence.eos; Precedence token; for (int i = 0; i < infix.length(); i++) { token = getToken(infix.charAt(i)); /** if token is operand append to postfix **/ if (token == Precedence.operand) postfix = postfix + infix.charAt(i); /** if token is right parenthesis pop till matching left parenthesis **/ else if (token == Precedence.rparen) { while (stack[top] != Precedence.lparen) postfix = postfix + operators[pop().getIndex()]; /** discard left parenthesis **/ pop(); } /** else pop stack elements whose precedence is greater than that of token **/ else { while (isp[stack[top].getIndex()] >= icp[token.getIndex()]) postfix = postfix + operators[pop().getIndex()]; push(token); } } /** pop any remaining elements in stack **/ while ((token = pop()) != Precedence.eos) postfix = postfix + operators[token.getIndex()]; return postfix; } /** Main function **/ public static void main (String[] args) { Scanner scan = new Scanner(System.in); System.out.println("Shunting Yard Algorithm Test\n"); /** Make an object of ShuntingYard class **/ ShuntingYard sy = new ShuntingYard(); /** Accept infix expression **/ System.out.println("Enter infix expression"); String infix = scan.next(); String postfix = sy.postfix(infix); System.out.println("\nPostfix expression : "+ postfix); } }
Output:
Shunting Yard Algorithm Test Enter infix expression 1+2*3/4-5%6*7/8+9-1 Postfix expression : 123*4/+56%7*8/-9+1-
Related posts:
Interface trong Java 8 – Default method và Static method
Java Program to Implement Kosaraju Algorithm
Java Program to Implement Solovay Strassen Primality Test Algorithm
Java Program to Implement AVL Tree
Java Program to Find ith Largest Number from a Given List Using Order-Statistic Algorithm
Flattening Nested Collections in Java
Serialize Only Fields that meet a Custom Criteria with Jackson
Các kiểu dữ liệu trong java
A Guide to JUnit 5 Extensions
The StackOverflowError in Java
How to Define a Spring Boot Filter?
Sending Emails with Java
Hướng dẫn sử dụng Java Reflection
Java Program to Check for balanced parenthesis by using Stacks
An Intro to Spring Cloud Contract
Làm thế nào tạo instance của một class mà không gọi từ khóa new?
Java Program to Implement Max Heap
Quick Guide to java.lang.System
File Upload with Spring MVC
Remove HTML tags from a file to extract only the TEXT
A Guide to Apache Commons Collections CollectionUtils
Hướng dẫn Java Design Pattern – Memento
Spring Boot - Building RESTful Web Services
Java Program to Implement Singly Linked List
Java Program to Check Cycle in a Graph using Topological Sort
Java Program to Implement RoleUnresolvedList API
Introduction to the Java NIO2 File API
Java Program to Implement Bubble Sort
Deploy a Spring Boot App to Azure
Extra Login Fields with Spring Security
Java Program to Find Nearest Neighbor for Static Data Set
Java – Reader to String