Intuition
Code
Python3
def invertTree(self, root: Optional[TreeNode]) -> Optional[TreeNode]:
if not root: return None
root.left, root.right = root.right, root.left
self.invertTree(root.left)
self.invertTree(root.right)
return root
Big O Analysis
-
Runtime
The runtime complexity here is since we are visiting every node in the tree.
-
Memory
The memory usage is since we are not using any extra data structure (other than the input binary tree).
— A