Skip to content

LeetCode 2415 Reverse Odd Levels of Binary Tree

Published: at 06:23 AM

Table of contents

Open Table of contents

Description

Given the root of a perfect binary tree, reverse the node values at each odd level of the tree.

Return the root of the reversed tree.

A binary tree is perfect if all parent nodes have two children and all leaves are on the same level.

The level of a node is the number of edges along the path between it and the root node.

Example 1:

tree image 1

Input: root = [2,3,5,8,13,21,34]
Output: [2,5,3,8,13,21,34]
Explanation:
The tree has only one odd level.
The nodes at level 1 are 3, 5 respectively, which are reversed and become 5, 3.

Example 2:

tree image 2

Input: root = [7,13,11]
Output: [7,11,13]
Explanation:
The nodes at level 1 are 13, 11, which are reversed and become 11, 13.

Example 3:

Input: root = [0,1,2,0,0,0,0,1,1,1,1,2,2,2,2]
Output: [0,2,1,0,0,0,0,2,2,2,2,1,1,1,1]

Explanation:
The odd levels have non-zero values.
The nodes at level 1 were 1, 2, and are 2, 1 after the reversal.
The nodes at level 3 were 1, 1, 1, 1, 2, 2, 2, 2, and are 2, 2, 2, 2, 1, 1, 1, 1 after the reversal.

Constraints:

Hint 1

Try to solve recursively for each level independently.

Hint 2

While performing a depth-first search, pass the left and right nodes (which should be paired) to the next level. If the current level is odd, then reverse their values, or else recursively move to the next level.

Idea

We could use dfs to traverse the tree.

  1. Because we need to be able to reverse, i.e., to swap the values of two nodes, we need access to the two nodes. From the root node, we could traverse to the left and right child.
  2. We use a d (depth) variable to track how deep we have traveled from the root.
  3. If the depth is odd, we perform a swap.
  4. We recursively traverse to the next level by visiting the children nodes of the two currently being visited nodes in mirror.

Complexity: Time O(n)O(n), Space O(logn)O(\log n).

Python

class Solution:
    """11 ms, 22.92 mb"""

    def reverseOddLevels(self, root) -> TreeNode:
        def dfs(l, r, d):
            if l is None or r is None: return
            if d % 2 == 1: l.val, r.val = r.val, l.val
            dfs(l.left, r.right, d + 1)
            dfs(l.right, r.left, d + 1)

        dfs(root.left, root.right, 1)
        return root

Previous Post
LeetCode 423 LintCode 1247 Reconstruct Original Digits from English
Next Post
LintCode 2503 Thread Safe Counter (Concurrency)