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

Pythonですべての葉が同じレベルにあるかどうかを確認するプログラム


二分木があるとしましょう。すべての葉が同じレベルにあるかどうかを確認する必要があります。

したがって、入力が次のような場合

Pythonですべての葉が同じレベルにあるかどうかを確認するプログラム

その場合、出力はTrueになります

これを解決するには、次の手順に従います-

  • 関数dfs()を定義します。これは根を下ろします、d

  • ルートがnullでない場合、

    • ルートの左側がnullで、ルートの右側がnullの場合、

      • 深さの終わりにdを挿入します

    • それ以外の場合

      • dfs(ルートの左側、d + 1)

      • dfs(ルートの右、d + 1)

  • メインの方法から、次のようにします-

  • 深さ:=新しいリスト

  • dfs(root、0)

  • 深さが1つの値しかない場合はtrueを返します

理解を深めるために、次の実装を見てみましょう-

class TreeNode:
   def __init__(self, value):
      self.val = value
      self.left = None
      self.right = None

class Solution:
   def solve(self, root):
      self.depth = []
      self.dfs(root, 0)
      return len(set(self.depth)) == 1
   def dfs(self, root, depth):
      if root:
         if not root.left and not root.right:
            self.depth.append(depth)
         else:
            self.dfs(root.left, depth + 1)
            self.dfs(root.right, depth + 1)
ob = Solution()
root = TreeNode(5)
root.left = TreeNode(4)
root.left.left = TreeNode(2)
root.right = TreeNode(10)
root.right.left = TreeNode(7)
root.right.right = TreeNode(15)
print(ob.solve(root))

入力

root = TreeNode(5)
root.left = TreeNode(4)
root.left.left = TreeNode(2)
root.right = TreeNode(10)
root.right.left = TreeNode(7)
root.right.right = TreeNode(15)

出力

True

  1. Pythonで二分木がBSTであるかどうかをチェックするプログラム

    二分木があるとしましょう。二分探索木かどうかを確認する必要があります。私たちが知っているように、BSTには次のプロパティがあります- 左側のサブツリーのすべてのノードが現在のノード値よりも小さい 右側のサブツリーのすべてのノードが現在のノード値よりも大きい これらのプロパティは、すべてのノードに対して再帰的に保持されます したがって、入力が次のような場合 その場合、出力はTrueになります これを解決するには、次の手順に従います- x:=ツリー要素の順序どおりの走査シーケンスのリスト xがソートされている場合、 trueを返す falseを返す 理解を深めるために

  2. Pythonで1つの値がBSTに存在するかどうかを確認するプログラム

    二分探索木とvalという別の入力があるとすると、valがツリーに存在するかどうかを確認する必要があります。 したがって、入力が次のような場合 val =7の場合、ツリーに7が存在するため、出力はTrueになります。 これを解決するために、次の手順に従います- 関数solve()を定義します。これはルートになります、val ルートがnullの場合、 Falseを返す ルートのデータがvalと同じ場合、 Trueを返す ルートのデータが