For example:
Given a binary tree
{1,2,3,4,5}
,1 / \ 2 3 / \ 4 5
return the root of the binary tree
[4,5,2,#,#,3,1]
.4 / \ 5 2 / \ 3 1
confused what
"{1,#,2,3}"
means? > read more on how binary tree is serialized on OJ.
Show Tags
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
public class Solution {
public TreeNode upsideDownBinaryTree(TreeNode root) {
if (root == null || root.left == null) return root;
TreeNode oldLeft = root.left;
TreeNode oldRight = root.right;
TreeNode newRoot = upsideDownBinaryTree(oldLeft);
oldLeft.left = oldRight;
oldLeft.right = root;
root.left = null;
root.right = null;
return newRoot;
}
}
========
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
public class Solution {
public TreeNode upsideDownBinaryTree(TreeNode root) {
TreeNode pre = null;
TreeNode cur = root;
TreeNode oldRight = null;
while (cur != null) {
TreeNode next = cur.left;
cur.left = oldRight;
oldRight = cur.right;
cur.right = pre;
pre = cur;
cur = next;
}
return pre;
}
}
没有评论:
发表评论