এক্সপ্রেশন ট্রি হল সেইগুলি যেগুলিতে লিফ নোডগুলিকে পরিচালনা করার মান থাকে এবং অভ্যন্তরীণ নোডগুলিতে সেই অপারেটর থাকে যার উপর লিফ নোডটি সঞ্চালিত হবে৷
উদাহরণ:4 + ((7 + 9) * 2) -
এর মত একটি এক্সপ্রেশন ট্রি থাকবে
এই সমস্যা সমাধানের পদ্ধতি
একটি প্রদত্ত অভিব্যক্তির জন্য একটি এক্সপ্রেশন ট্রি তৈরি করার জন্য, আমরা সাধারণত স্ট্যাক ডেটা স্ট্রাকচার ব্যবহার করি। প্রাথমিকভাবে আমরা প্রদত্ত পোস্টফিক্স এক্সপ্রেশনের উপর পুনরাবৃত্তি করি এবং নীচে দেওয়া পদক্ষেপগুলি অনুসরণ করি -
- যদি আমরা প্রদত্ত এক্সপ্রেশনে একটি অপারেন্ড পাই, তাহলে এটিকে স্ট্যাকের মধ্যে পুশ করুন। এটি অভিব্যক্তি গাছের মূলে পরিণত হবে।
- যদি কোনো অপারেটর এক্সপ্রেশনে দুটি মান পায়, তাহলে এক্সপ্রেশন ট্রিতে তার চাইল্ড হিসেবে যোগ করুন এবং সেগুলোকে বর্তমান নোডে পুশ করুন।
- ধাপ-1 এবং ধাপ-2 পুনরাবৃত্তি করুন যতক্ষণ না আমরা আমাদের প্রদত্ত অভিব্যক্তিটি সম্পূর্ণ না করি।
উদাহরণ
class stack: def __init__(self): self.arr = [] def push(self, data): self.arr.append(data) def pop(self): try: return self.arr.pop(-1) except: pass def top(self): try: return self.arr[-1] except: pass def size(self): return len(self.arr) # node class for expression tree class node: def __init__(self, data): self.data = data self.left = None self.right = None # expression tree class class exp_tree: def __init__(self, postfix_exp): self.exp = postfix_exp self.root = None self.createTree(self.exp) def isOperator(self, char): optr = [" ", "-", "*", "/", "^"] if char in optr: # if given char is operator return True # then return true return False # else return false def createTree(self, exp): s = stack() # store those operator node whose any child node is NULL self.root = node(exp[-1]) # last character of postfix expression is always an operator s.push(self.root) # travel on rest of the postfix expression for i in "".join(reversed(exp[:-1])): curr_node = s.top() if not curr_node.right: # if right node of current node is NULL temp = node(i) curr_node.right = temp if self.isOperator(i): s.push(temp) else: # if left node of current node is NULL temp = node(i) curr_node.left = temp # if no child node of current node is NULL s.pop() # pop current from stack if self.isOperator(i): s.push(temp) def inorder(self, head): # inorder traversal of expression tree # inorder traversal = > left, root, right if head.left: self.inorder(head.left) print(head.data, end=" ") if head.right: self.inorder(head.right) def infixExp(self): # inorder traversal of expression tree give infix expression self.inorder(self.root) print() if __name__ == "__main__": postfixExp = "ab ef*g*-" et = exp_tree(postfixExp) et.infixExp()
উপরের কোডটি চালানোর ফলে আউটপুট তৈরি হবে,
আউটপুট
(a + b - e * f * g)
ব্যাখ্যা:
একটি প্রদত্ত এক্সপ্রেশন থেকে একটি ট্রি তৈরি করা আউটপুট তৈরি করবে যাতে অপারেন্ডটি নোডের রুট হয়ে যাবে এবং বাকি সংখ্যাগুলি এক্সপ্রেশন ট্রির চাইল্ড নোড হয়ে যাবে৷