Computer >> Máy Tính >  >> Lập trình >> Python

Chương trình kiểm tra xem cây đã cho có phải là cây đối xứng hay không trong Python

Giả sử chúng ta có một cây nhị phân. Chúng ta phải kiểm tra xem cây có phải là cây đối xứng hay không. Một cái cây sẽ được cho là đối xứng nếu nó giống nhau khi chúng ta chụp ảnh phản chiếu của nó. Từ hai cây này, cây đầu tiên là đối xứng, nhưng cây thứ hai thì không.

Chương trình kiểm tra xem cây đã cho có phải là cây đối xứng hay không trong Python

Chương trình kiểm tra xem cây đã cho có phải là cây đối xứng hay không trong Python

Để giải quyết vấn đề này, chúng tôi sẽ làm theo các bước sau.

  • Chúng tôi sẽ gọi các bước sau một cách đệ quy. Hàm sẽ được giải quyết (root, root)

  • nếu node1 và node2 trống, thì trả về true

  • nếu node1 hoặc node2 trống, thì trả về false

  • trả về true khi node1.val =node2.val và giải quyết (node1.left, node2.right) và giải quyết (node1.right, node2.left)

Hãy cùng chúng tôi xem cách triển khai sau để hiểu rõ hơn -

Ví dụ

class TreeNode:
   def __init__(self, data, left = None, right = None):
      self.data = data
      self.left = left
      self.right = right
class Solution(object):
   def isSymmetric(self, root):
      return self.solve(root,root)
   def solve(self,node1,node2):
      if not node1 and not node2:
         return True
      if not node1 or not node2:
         return False
      return node1.data == node2.data and
self.solve(node1.left,node2.right) and
self.solve(node1.right,node2.left)
root = TreeNode(1)
root.left = TreeNode(2)
root.right = TreeNode(2)
root.left.left = TreeNode(3)
root.left.right = TreeNode(4)
root.right.left = TreeNode(4)
root.right.right = TreeNode(3)
ob1 = Solution()
print(ob1.isSymmetric(root))

Đầu vào

root = TreeNode(1)
root.left = TreeNode(2)
root.right = TreeNode(2)
root.left.left = TreeNode(3)
root.left.right = TreeNode(4)
root.right.left = TreeNode(4)
root.right.right = TreeNode(3)

Đầu ra

True