CONVERT INFIX EXPRESSION INTO POSTFIX EXPRESSION

 CONVERT INFIX EXPRESSION INTO POSTFIX EXPRESSION

 

#Formulate a program to convert infix
#expression into postfix expression.
class Stack:
    def __init__(self):
        self.items=[]
        self.length=0

    def push(self,val):
        self.items.append(val)
        self.length+=1
    def pop(self):
        if self.empty():
            return None
        self.length-=1
        return self.items.pop()

    def size(self):
        return self.length

    def peek(self):
        if self.empty():
            return None
        return self.items[0]

    def empty(self):
        return (self.length==0)

    def __str__(self):
        return str(self.items)


def convert(expression):
    print(__convert(expression.split()))

def __convert(tokens):
    postfix=[]
    opstack=Stack()

    precedence={}
    precedence['*']=3
    precedence['/']=3
    precedence['+']=2
    precedence['-']=2
    precedence['(']=1
    for token in tokens:
        if token.isidentifier():#a b c d e
            postfix.append(token)
        elif token=='(':
            opstack.push(token)
        elif token==')':
            while True:
                temp=opstack.pop()
                if temp is None or temp=='(':
                    break
                elif not temp.isidentifier():
                    postfix.append(temp)
        #
        else:#must be operator
            if not opstack.empty():
                temp=opstack.peek()
                while not opstack.empty() and precedence[temp]>= precedence[token] and token.isidentifier():
                    postfix.append(opstack.pop())
                    temp=opstack.peek()
            opstack.push(token)

    while not opstack.empty():
        postfix.append(opstack.pop())
    return postfix

convert("A + B")
convert("A + B * C")
convert("A * ( B + C ) + D")           




 

Comments

Popular posts from this blog

SAME NAME IN CLASS METHOD AND CONSTRUCTOR

PALINDROME NUMBER

FIBONACCI SERIES