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

左側のサブツリーのノードのみを印刷するPythonプログラム


左側のサブツリーのノードを印刷する必要がある場合は、ルートノードを設定し、順番にトラバーサルを実行し、ルートノードの右側、左側に要素を挿入するメソッドを定義できるクラスを作成できます。ルートノードなど。クラスのインスタンスが作成され、メソッドを使用して必要な操作を実行できます。

以下は同じのデモンストレーションです-

class BinaryTree_struct:
   def __init__(self, data=None):
      self.key = data
      self.left = None
      self.right = None

   def set_root(self, data):
      self.key = data

   def inorder_traversal(self):
      if self.left is not None:
         self.left.inorder_traversal()
      print(self.key, end=' ')
      if self.right is not None:
         self.right.inorder_traversal()

   def insert_at_left(self, new_node):
      self.left = new_node

   def insert_at_right(self, new_node):
      self.right = new_node

   def search_elem(self, key):
      if self.key == key:
         return self
      if self.left is not None:
         temp = self.left.search_elem(key)
         if temp is not None:
            return temp
      if self.right is not None:
         temp = self.right.search_elem(key)
         return temp
      return None

   def print_left_part(self):
      if self.left is not None:
         self.left.inorder_traversal()

my_instance = None

print('Menu (this assumes no duplicate keys)')
print('insert <data> at root')
print('insert <data> left of <data>')
print('insert <data> right of <data>')
print('left')
print('quit')

while True:
   my_input = input('What operation would you do ? ').split()

   operation = my_input[0].strip().lower()
   if operation == 'insert':
      data = int(my_input[1])
      new_node = BinaryTree_struct(data)
      suboperation = my_input[2].strip().lower()
      if suboperation == 'at':
         my_instance = new_node
      else:
         position = my_input[4].strip().lower()
         key = int(position)
         ref_node = None
         if my_instance is not None:
            ref_node = my_instance.search_elem(key)
         if ref_node is None:
            print('No such key')
            continue
         if suboperation == 'left':
            ref_node.insert_at_left(new_node)
         elif suboperation == 'right':
            ref_node.insert_at_right(new_node)

   elif operation == 'left':
      print('Nodes of the left subtree are : ', end='')
      if my_instance is not None:
         my_instance.print_left_part()
         print()

   elif operation == 'quit':
      break
>

出力

Menu (this assumes no duplicate keys)
insert <data> at root
insert <data> left of <data>
insert <data> right of <data>
left
quit
What operation would you do ? insert 5 at root
What operation would you do ? insert 6 left of 5
What operation would you do ? insert 8 right of 5
What operation would you do ? left
Nodes of the left subtree are : 6
What operation would you do ? quit
Use quit() or Ctrl-D (i.e. EOF) to exit

説明

  • 必要な属性を持つ「BinaryTree_struct」クラスが作成されます。

  • 左右のノードを「なし」に割り当てるために使用される「init」関数があります。

  • 二分木のルート値を設定するのに役立つ「set_root」メソッドが定義されています。

  • ツリーの右側のノードに要素を追加するのに役立つ「insert_at_right」メソッドがあります。

  • ツリーの左側のノードに要素を追加するのに役立つ「insert_at_left」メソッドがあります。

  • 順序トラバーサルを実行する「inorder_traversal」という名前の別のメソッド。

  • 「search_elem」という名前のメソッドが定義されており、特定の要素の検索に役立ちます。

  • 「print_left_part」という名前の別のメソッドが定義されています。これは、コンソールにバイナリツリーの左側の部分のみを表示するのに役立ちます。

  • インスタンスが作成され、「なし」に割り当てられます。

  • 実行する必要のある操作に対してユーザー入力が行われます。

  • ユーザーの選択に応じて、操作が実行されます。•関連する出力がコンソールに表示されます。


  1. Pythonで1つのツリーが他のツリーのサブツリーであるかどうかを確認するプログラム

    2つの二分木があるとします。 2番目のツリーが最初のツリーのサブツリーであるかどうかを確認する必要があります。 したがって、入力が次のような場合 その場合、出力はTrueになります。 これを解決するには、次の手順に従います- 関数solve()を定義します。これはルート、ターゲットになります ルートがnullで、ターゲットもnullの場合、 Trueを返す ルートがnullまたはターゲットがnullの場合、 Falseを返す ルートの値がターゲットの値と同じである場合、 戻り値solve(ルートの左、ターゲットの左)とsolve(ル

  2. 行列をZ形式で印刷するPythonプログラム

    この記事では、特定の問題ステートメントを解決するための解決策とアプローチについて学習します。 問題の説明 −次数n * nの正方行列が与えられた場合、行列の要素をZ形式で表示する必要があります。 Zフォームは、次の手順でマトリックスをトラバースしています- 最初の行をトラバースします 次に、2番目の主対角線を横断します 最後に、最後の行をトラバースします。 ここでは、code.demostrateのフローを示すために暗黙的に取得された入力マトリックスを取得します。 例 arr = [[1, 2, 6, 9],    [1, 2, 3, 1],   &nb