# [156. Binary Tree Upside Down](https://leetcode.com/problems/binary-tree-upside-down) [中文文档](/solution/0100-0199/0156.Binary%20Tree%20Upside%20Down/README.md) ## Description <p>Given the <code>root</code> of a binary tree, turn the tree upside down and return <em>the new root</em>.</p> <p>You can turn a binary tree upside down with the following steps:</p> <ol> <li>The original left child becomes the new root.</li> <li>The original root becomes the new right child.</li> <li>The original right child becomes the new left child.</li> </ol> <p><img alt="" src="https://cdn.jsdelivr.net/gh/doocs/leetcode@main/solution/0100-0199/0156.Binary%20Tree%20Upside%20Down/images/main.jpg" style="width: 100%; height: 100%;" /></p> <p>The mentioned steps are done level by level, it is <strong>guaranteed</strong> that every node in the given tree has either <strong>0 or 2 children</strong>.</p> <p> </p> <p><strong>Example 1:</strong></p> <img alt="" src="https://cdn.jsdelivr.net/gh/doocs/leetcode@main/solution/0100-0199/0156.Binary%20Tree%20Upside%20Down/images/updown.jpg" style="width: 800px; height: 161px;" /> <pre> <strong>Input:</strong> root = [1,2,3,4,5] <strong>Output:</strong> [4,5,2,null,null,3,1] </pre> <p><strong>Example 2:</strong></p> <pre> <strong>Input:</strong> root = [] <strong>Output:</strong> [] </pre> <p><strong>Example 3:</strong></p> <pre> <strong>Input:</strong> root = [1] <strong>Output:</strong> [1] </pre> <p> </p> <p><strong>Constraints:</strong></p> <ul> <li>The number of nodes in the tree will be in the range <code>[0, 10]</code>.</li> <li><code>1 <= Node.val <= 10</code></li> <li><code>Every node has either 0 or 2 children.</code></li> </ul> ## Solutions <!-- tabs:start --> ### **Python3** ```python # Definition for a binary tree node. # class TreeNode: # def __init__(self, val=0, left=None, right=None): # self.val = val # self.left = left # self.right = right class Solution: def upsideDownBinaryTree(self, root: Optional[TreeNode]) -> Optional[TreeNode]: if root is None or root.left is None: return root new_root = self.upsideDownBinaryTree(root.left) root.left.right = root root.left.left = root.right root.left = None root.right = None return new_root ``` ### **Java** ```java /** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val = val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val = val; * this.left = left; * this.right = right; * } * } */ class Solution { public TreeNode upsideDownBinaryTree(TreeNode root) { if (root == null || root.left == null) { return root; } TreeNode newRoot = upsideDownBinaryTree(root.left); root.left.right = root; root.left.left = root.right; root.left = null; root.right = null; return newRoot; } } ``` ### **C++** ```cpp /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: TreeNode* upsideDownBinaryTree(TreeNode* root) { if (!root || !root->left) return root; TreeNode* newRoot = upsideDownBinaryTree(root->left); root->left->right = root; root->left->left = root->right; root->left = nullptr; root->right = nullptr; return newRoot; } }; ``` ### **Go** ```go /** * Definition for a binary tree node. * type TreeNode struct { * Val int * Left *TreeNode * Right *TreeNode * } */ func upsideDownBinaryTree(root *TreeNode) *TreeNode { if root == nil || root.Left == nil { return root } newRoot := upsideDownBinaryTree(root.Left) root.Left.Right = root root.Left.Left = root.Right root.Left = nil root.Right = nil return newRoot } ``` ### **...** ``` ``` <!-- tabs:end -->