156. Binary Tree Upside Down
Difficulty: Medium
Topics: Tree
Similar Questions:
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;
}
};