Python
 Computer >> コンピューター >  >> プログラミング >> Python

特定の式の式ツリーを構築するPythonプログラム


式ツリーは、リーフノードが操作される値を持ち、内部ノードがリーフノードが実行される演算子を含むツリーです。

例:4 +((7 + 9)* 2) -

のような式ツリーがあります

特定の式の式ツリーを構築するPythonプログラム

この問題を解決するためのアプローチ

特定の式の式ツリーを構築するために、通常、スタックデータ構造を使用します。最初に、指定された接尾辞式を繰り返し処理し、以下の手順に従います-

  • 指定された式でオペランドを取得した場合は、それをスタックにプッシュします。これは、式ツリーのルートになります。
  • 演算子が式で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)

説明:

指定された式からツリーを構築すると、オペランドがノードのルートになり、残りの数値が式ツリーの子ノードになるように出力が生成されます。


  1. Pythonの二分木ぬりえゲーム

    二分木でターン制のゲームをプレイする2人のプレーヤーがいるとします。この二分木のルートとツリー内のノード数nがあります。ここで、nは奇数であり、各ノードには1からnまでの異なる値があります。最初に、最初のプレーヤーは値xに1 <=x <=nの名前を付け、2番目のプレーヤーは値yに1 <=y <=nの名前を付け、y!=xのような条件を保持します。最初のプレーヤーはノードを値xの赤で色付けし、2番目のプレーヤーはノードを値yの青で色付けします。その後、プレイヤーは最初のプレイヤーから順番に順番に進みます。各ターンで、プレーヤーは自分の色のノード(プレーヤー1の場合は赤、プレーヤー2の場合は青)を取

  2. Pythonでの二分木の直径

    二分木があるとしましょう。木の直径の長さを計算する必要があります。二分木の直径は、実際には、ツリー内の任意の2つのノード間の最長パスの長さです。このパスは必ずしもルートを通過する必要はありません。したがって、ツリーが以下のようになっている場合、パスの長さ[4,2,1,3]または[5,2,1,3]は3であるため、直径は3になります。 これを解決するには、次の手順に従います- dfsを使用して直径を見つけ、答えを設定します:=0 ルートdfs(root)を使用してdfs関数を呼び出します dfsは以下のdfs(node)のように機能します ノードが存在しない場合は、0を返します 左