Infix, Prefix dan Postfix pada Python


A. Definisi
Infix adalah cara penulisan atau ungkapan yang meletakan operator di tengah antara 2 operand dalam hal ini dalam kurung sangat menentukan posisi.
Contoh Infix :
A + B
( A - B ) * C

Prefix adalah cara penulisan atau ungkapan yang meletakan operator disebelah kiri 2 operand dan dalam kurung sangat menentukan posisi.
Contoh Prefix :
+ A B
* - A B C

Posfix adalah cara penulisan yang meletakan operator disebelah kanan 2 operand dan posisi operand yang berada di dalam kurung sangat menentukan.
Contoh Postfix :
A B +
A B - C *

B. Ilustrasi




C. Algoritma
Berikut ini algoritma dari konversi Infix ke Postfix:


  1. Buat presisi atau kekuatan operator ( Penjumlahan dan Pengurangan bernilai 2 , Perkalian dan Pembagian bernilai 3 , Kurang buka dan tutup bernilai 1 )
  2. Input data dalam bentuk infix
  3. Pisahkan data infix menggunakan split menjadi bentuk List
  4. Periksa semua data yang berada di dalam list secara urut mulai dari awal hingga akhir
  5. Jika bertemu operand, maka masukan data ke PostfixList untuk dicetak
  6. Jika bertemu kurung buka '(' maka masukan ke Stack Operator
  7. Jika bertemu kurung tutup ')' maka Stack Operator yang paling atas dan bukan kurung buka '(' diambil untuk dicetak ke PostfixList
  8. Jika bertemu operator maka jika Stack Operator tidak kosong dan kekuatan operator yang digunakan lebih kecil dari kekuatan operator yang berada di top Stack Operator maka operator yang berada di Stack Operator diambil (pop) untuk dicetak di PostfixList. lalu masukan operator yang digunakan ke dalam Stack Operator.
  9. Begitu seterusnya sampai List yang berisi data Infix habis.
  10. Jika Stack Operator masih ada isinya maka ambil dan tambahkan ke PostfixList untuk dicetak.
  11. Cetak PostfixList
Berikut ini Algoritma dari konversi Infix ke Prefix:
  1. Balikan data Infix
  2. Jika operator kurung buka '(' maka ganti dengan kurung tutup ')' begitu sebaliknya
  3. Masukan data tersebut ke konversi Infix ke Postfix 
  4. Setelah keluar hasil, Balikan lagi hasil tersebut
  5. Maka keluar bentuk Prefix
D. Kode Program 
Berikut ini kode program Konversi dari Infix ke bentuk Postfix :

  1. class Stack:
  2.     def __init__(self):
  3.         self.items = []
  4.     def isEmpty(self):
  5.         return self.items == []
  6.     def push(self, items):
  7.         self.items.append(items)
  8.     def pop(self):
  9.         return self.items.pop()
  10.     def peek(self):
  11.         return self.items[len(self.items)-1]

  12. def infixToPostfix(infixexpr):
  13.     prec = {}
  14.     prec["*"] = 3
  15.     prec["/"] = 3
  16.     prec["+"] = 2
  17.     prec["-"] = 2
  18.     prec["("] = 1
  19.     opStack = Stack()
  20.     postfixList = []
  21.     tokenList = infixexpr.split()

  22.     for token in tokenList:
  23.         if token in "ABCDEFGHIJKLMNOPQRSTUVWXYZ" or token in "0123456789":
  24.             postfixList.append(token)
  25.         elif token == '(':
  26.             opStack.push(token)
  27.         elif token == ')':
  28.             topToken = opStack.pop()
  29.             while topToken != '(':
  30.                 postfixList.append(topToken)
  31.                 topToken = opStack.pop()
  32.         else:
  33.             while (not opStack.isEmpty()) and \
  34.                (prec[opStack.peek()] >= prec[token]):
  35.                   postfixList.append(opStack.pop())
  36.             opStack.push(token)

  37.     while not opStack.isEmpty():
  38.         postfixList.append(opStack.pop())
  39.     return " ".join(postfixList)

  40. print(infixToPostfix("A * B + C * D"))


Kode Program konversi Infix ke Prefix :

  • class Stack:
  •     def __init__(self):
  •         self.items = []
  •     def isEmpty(self):
  •         return self.items == []
  •     def push(self, items):
  •         self.items.append(items)
  •     def pop(self):
  •         return self.items.pop()
  •     def peek(self):
  •         return self.items[len(self.items)-1]
  • def size(self):
  •          return len(self.items)
  •     def showList(self):
  •           return self.items

  • def infixToPrefix(infixexpr):
  •     
  •     prec = {'*':3, '/':3 , '+':2, '-':2 , '(':1}
  •     opStack = Stack()
  •     prefixList = []
  •     tokenList = infixexpr.split()
  •     tokenList.reverse()
  •     for i in range(len(tokenList)):
  •          if tokenList[i] == '(':
  •               tokenList[i]=')'
  •          elif tokenList[i] == ')':
  •               tokenList[i]='('
  •     for token in tokenList:
  •         if token in "ABCDEFGHIJKLMNOPQRSTUVWXYZ" or token in "0123456789":
  •             prefixList.append(token)
  •         elif token == '(':
  •             opStack.push(token)
  •         elif token == ')':
  •             topToken = opStack.pop()
  •             
  •             while topToken != '(':
  •                 prefixList.append(topToken)
  •                 topToken = opStack.pop()
  •         else:
  •             while (not opStack.isEmpty()) and \
  •                (prec[opStack.peek()] >= prec[token]):
  •                   prefixList.append(opStack.pop())
  •             opStack.push(token)

  •     while not opStack.isEmpty():
  •         prefixList.append(opStack.pop())
  •     prefixList = prefixList[::-1]
  •     return " ".join(prefixList)

  • print(infixToPrefix("A * B - C * D"))
  • print(infixToPrefix("( A + B ) * C - ( D - E ) * ( F + G )"))

  • Komentar

    Postingan populer dari blog ini

    Dequeue

    Shell Sort