Skip to main content

Polish Notation in Data Structure Vijay Sinha The Crazy Programmer

In this article, we will look into Polish notation in Data Structures. We will discuss its types along with some examples and the use of such notations in general.

Polish Notation is a general form of expressing mathematical, logical and algebraic equations. The compiler uses this notation in order to evaluate mathematical expressions depending on the order of operations. There are in general three types of Notations used while parsing Mathematical expressions:

  • Infix Notation
  • Prefix Notation
  • Postfix Notation

Infix Notation or Expression is where the operators are written in between every pair of operands. It is the usual way to write an expression generally written with parentheses. For Ex: An expression like X+Y is an Infix Expression, where + is an Operator and X, Y are Operands.

Polish Notation in Data Structure

Now, Polish Notation is also known as Prefix Notation or Expression. In this type of arithmetic expression, the operators precede the operands i.e. the operators are written before the Operands. The operators are placed left for every pair of operands. So, for the above Infix X+Y, its equivalent Polish or Prefix Notation is +XY.

Evaluation with Example

Now, let us look at an example on how to evaluate a Polish Notation or Prefix Expression to get the result.

Consider this Expression : / * + 5 6 3 11. While evaluating the expression we take decision for two cases: When the Character is an Operand or When the Character is an Operator. Let us look at the steps.

Step 1:

We will use a Stack for this evaluation.We scan the Expression from right to left, if the current character is an Operand we push it into the stack. So from 11 to 5 we push the elements into the stack. The stack looks:

Step 2:

As soon as we get an operator we multiply its previous two elements, so continuing traversing from right to left we first get ‘+’ operator so we pop two elements from stack (5 & 6) compute their result with the operator i.e. 5+6 = 11, and push the result back into the stack for future evaluation. The Stack now is:

Step 3:

The next Operator is ‘*’ Operator (Multiply), so we again pop the two elements from stack and repeating the process of Step 2. So we compute the result from their operation (11 * 3 =33) and push it back to the stack again. The stacks now look like:

Step 4:

Finally, we have the ‘/’ operator so we pop 33 and 11 compute the result push it back to the stack. Now we have reached the leftmost or start index of the expression so at this point our stack will contains only one value which will be our Resultant Evaluated Prefix Expression.

At the End Stack Contains Value 3 which is the result of Evaluation.

Let us look at the implementation code for this in Java:

import java.util.*;

public class PolishNotation
{
  static boolean isOperator(String ch)
  {
      if(ch.equals("+") || ch.equals("-") || ch.equals("*") || ch.equals("/"))
      return true;
      
      return false;
  }     
    
  static int evaluatePrefix(String exp[])
  {
      // get the length of exp array
      int n= exp.length;
      // stack to evaluate result.
      Stack<Integer> st = new Stack<>();
      
      for(int i=n-1;i>=0;i--)
      {
          // check if each value in array is an operator or not.
          if(isOperator(exp[i]))
          {
              int first = st.pop();
              int second = st.pop();
              
              // Now we evaluate for each pair of operands and push the result into the stack.
              if(exp[i].equals("+"))
              {
                  int temp = first + second;
                  st.push(temp);
              }
              else if(exp[i].equals("-"))
              {
                  int temp = first - second;
                  st.push(temp);
              }
              if(exp[i].equals("*"))
              {
                  int temp = first * second;
                  st.push(temp);
              }
              if(exp[i].equals("/"))
              {
                  int temp = first / second;
                  st.push(temp);
              }
              
          }
          else
          {
              // if operand just push into the stack.
              st.push(Integer.parseInt(exp[i]));
          }
      }
      // at the end stack will contain only one value which will be our result;
      
      return st.pop();
  }
    
  public static void main(String args[]) 
  {
      // We use the String representaion of the Prefix Expression.
      String exp = "/ * + 5 6 3 11";
      // we split the operators and operands on basis of space to avoid confusion with double digit numbers
      // and easy traversal.
      String exp_arr[]= exp.split(" ");
      // The array contains the operators and operands.
      
      System.out.println("The Polish Notation is : "+ exp);
      
      int result = evaluatePrefix(exp_arr);
      
      System.out.println("The Result after Evaluation is : "+result);
  }
  
}

Output:

The Polish Notation is : / * + 5 6 3 11
The Result after Evaluation is : 3

Reverse Polish Notation

Now, Polish Notation has Another Type – Reverse Polish Notation or also known as Postfix Expression. These are the expression where the Operands precede the Operators i.e. the Operands are written before the Operators. For Example: The Infix X+Y will be represented in Postfix or Reverse Polish as XY+.

Evaluation with Example

Now, let us see how to evaluate a given Postfix Expression. Consider this Reverse Polish or Postfix Expression: 4 3 2 + * 5 – .

Step 1:

We will again use a Stack for this evaluation. Here, We scan the Expression from left to right, if the current character is an Operand we push it into the stack. So from 4 to 2 we push the elements into the stack. The stack looks:

Step 2

Now, on traversing next we get ‘+’ operator, so we pop two elements from the stack compute their result and push it back again for future evaluation. The steps here are same as above discussed example. The difference is that in this case we traverse from left to right. The overall algorithm remains same. The stack now is:

Step 3:

Now, computing all the steps for each operator we get ‘*’ so we pop 5 and 4 and push 5 * 4 = 20 into stack and then we get 5 so we push into stack then finally we get ‘-‘ operator so we compute their result 5-20 = -15, then we push it again, at the end index of the string we get the result of our Postfix evaluation. The stack finally has -15.

Let us look at the implementation code in Java:

import java.util.*;

public class ReversePolishNotation
{
  static boolean isOperator(String ch)
  {
      if(ch.equals("+") || ch.equals("-") || ch.equals("*") || ch.equals("/"))
      return true;
      
      return false;
  }     
    
  static int evaluatePostfix(String exp[])
  {
      // get the length of exp array
      int n= exp.length;
      // stack to evaluate result.
      Stack<Integer> st = new Stack<>();
      // we traverse left to right
      for(int i=0;i<n;i++)
      {
          // check if each value in array is an operator or not.
          if(isOperator(exp[i]))
          {
              int first = st.pop();
              int second = st.pop();
              
              // Now we evaluate for each pair of operands and push the result into the stack.
              if(exp[i].equals("+"))
              {
                  int temp = first + second;
                  st.push(temp);
              }
              else if(exp[i].equals("-"))
              {
                  int temp = Math.abs(first - second);
                  st.push(temp);
              }
              if(exp[i].equals("*"))
              {
                  int temp = first * second;
                  st.push(temp);
              }
              if(exp[i].equals("/"))
              {
                  int temp = first / second;
                  st.push(temp);
              }
              
          }
          else
          {
              // if operand just push into the stack.
              st.push(Integer.parseInt(exp[i]));
          }
      }
      // at the end stack will contain only one value which will be our result;
      
      return st.pop();
  }
    
  public static void main(String args[]) 
  {
      // We use the String representaion of the Postfix Expression like above.
      String exp = "4 3 2 + * 5 -";
      // we split the operators and operands on basis of space to avoid confusion with double digit numbers
      // and easy traversal.
      String exp_arr[]= exp.split(" ");
      // The array contains the operators and operands.
      
      System.out.println("The Reverse Polish Notation is : "+ exp);
      
      int result = evaluatePostfix(exp_arr);
      
      System.out.println("The Result after Evaluation is : "+result);
  }
  
}

Output:

The Reverse Polish Notation is : 4 3 2 + * 5 -
The Result after Evaluation is : -15

Polish Notation Applications

  • Polish Notation is useful in representing the Mathematical Expression for the machines to understand them.
  • The compiler can easily evaluate these expressions without having to scan the expression for operators first then for operand which requires multiple scanning. By converting the Infix expression to Polish notation the compiler can then evaluate the expression in one go.
  • The modern Stack-organized computers are better suited for postfix and prefix notation than the traditional infix notation.

So that’s it for the article you can try out the above discussed steps with different examples and execute the code for better understanding. Feel free to leave your suggestion or doubts in the comment section below.

The post Polish Notation in Data Structure appeared first on The Crazy Programmer.



from The Crazy Programmer https://ift.tt/3tcVjoe

Comments

Popular posts from this blog

Difference between Web Designer and Web Developer Neeraj Mishra The Crazy Programmer

Have you ever wondered about the distinctions between web developers’ and web designers’ duties and obligations? You’re not alone! Many people have trouble distinguishing between these two. Although they collaborate to publish new websites on the internet, web developers and web designers play very different roles. To put these job possibilities into perspective, consider the construction of a house. To create a vision for the house, including the visual components, the space planning and layout, the materials, and the overall appearance and sense of the space, you need an architect. That said, to translate an idea into a building, you need construction professionals to take those architectural drawings and put them into practice. Image Source In a similar vein, web development and design work together to create websites. Let’s examine the major responsibilities and distinctions between web developers and web designers. Let’s get going, shall we? What Does a Web Designer Do?...

A guide to data integration tools

CData Software is a leader in data access and connectivity solutions. It specializes in the development of data drivers and data access technologies for real-time access to online or on-premise applications, databases and web APIs. The company is focused on bringing data connectivity capabilities natively into tools organizations already use. It also features ETL/ELT solutions, enterprise connectors, and data visualization. Matillion ’s data transformation software empowers customers to extract data from a wide number of sources, load it into their chosen cloud data warehouse (CDW) and transform that data from its siloed source state, into analytics-ready insights – prepared for advanced analytics, machine learning, and artificial intelligence use cases. Only Matillion is purpose-built for Snowflake, Amazon Redshift, Google BigQuery, and Microsoft Azure, enabling businesses to achieve new levels of simplicity, speed, scale, and savings. Trusted by companies of all sizes to meet...

2022: The year of hybrid work

Remote work was once considered a luxury to many, but in 2020, it became a necessity for a large portion of the workforce, as the scary and unknown COVID-19 virus sickened and even took the lives of so many people around the world.  Some workers were able to thrive in a remote setting, while others felt isolated and struggled to keep up a balance between their work and home lives. Last year saw the availability of life-saving vaccines, so companies were able to start having the conversation about what to do next. Should they keep everyone remote? Should they go back to working in the office full time? Or should they do something in between? Enter hybrid work, which offers a mix of the two. A Fall 2021 study conducted by Google revealed that over 75% of survey respondents expect hybrid work to become a standard practice within their organization within the next three years.  Thus, two years after the world abruptly shifted to widespread adoption of remote work, we are dec...