美文网首页
Tweaked Identical Binary Trees

Tweaked Identical Binary Trees

作者: GakkiLove | 来源:发表于2018-05-15 20:22 被阅读0次

Determine whether two given binary trees are identical assuming any number of ‘tweak’s are allowed. A tweak is defined as a swap of the children of one node in the tree.

Example:

        5

      /    \

    3        8

  /   \

1      4

and

        5

      /    \

    8        3

           /   \

          1     4

the two binary trees are tweaked identical.

How is the binary tree represented?

We use the level order traversal sequence with a special symbol "#" denoting the null node.

class Solution(object):
  def isTweakedIdentical(self, one, two):
    if one is None and two is None:
      return True
    if one and two and one.val == two.val:
      return self.isTweakedIdentical(one.left,two.right) and self.isTweakedIdentical(one.right,two.left) or self.isTweakedIdentical(one.left,two.left) and self.isTweakedIdentical(one.right,two.right)
    return False

相关文章

网友评论

      本文标题:Tweaked Identical Binary Trees

      本文链接:https://www.haomeiwen.com/subject/ckwydftx.html