156. Binary Tree Upside Down

Problem:

Given a binary tree where all the right nodes are either leaf nodes with a sibling (a left node that shares the same parent node) or empty, flip it upside down and turn it into a tree where the original right nodes turned into left leaf nodes. Return the new root.

Example:

Input: [1,2,3,4,5]

    1
   / \
  2   3
 / \
4   5

Output: return the root of the binary tree [4,5,2,#,#,3,1]

   4
  / \
 5   2
    / \
   3   1  

Clarification:

Confused what [4,5,2,#,#,3,1] means? Read more below on how binary tree is serialized on OJ.

The serialization of a binary tree follows a level order traversal, where '#' signifies a path terminator where no node exists below.

Here's an example:

   1
  / \
 2   3
    /
   4
    \
     5

The above binary tree is serialized as [1,2,3,#,#,4,#,#,5].

Solutions:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    TreeNode* upsideDownBinaryTree(TreeNode* root) {
        if (root == nullptr)    return nullptr;
        if (root->left == nullptr && root->right == nullptr)    return root;
        TreeNode* leftNode = root->left;
        TreeNode* rightNode = root->right;
        TreeNode* leftSubUpsideDown = upsideDownBinaryTree(leftNode);
        TreeNode* rightSubUpsideDown = upsideDownBinaryTree(rightNode);

        leftNode->left = rightSubUpsideDown;
        leftNode->right = root;

        root->left = nullptr; // set nullptr
        root->right = nullptr; // set nullptr

        return leftSubUpsideDown;
    }
};

results matching ""

    No results matching ""