题目描述
操作给定的二叉树,将其变换为源二叉树的镜像。
输入描述:
二叉树的镜像定义:源二叉树
8
/
6 10
/ \ /
5 7 9 11
镜像二叉树
8
/
10 6
/ \ /
11 9 7 5
终于过了hhhhh,跟正确解法可以说是差不多。(其实题也很水hhhh)
类似于前序遍历的代码,创建一个树为当前根节点的左节点(或者右节点)。
然后让根节点的左节点和右节点交换,一直遍历即可。
/**
public class TreeNode {
int val = 0;
TreeNode left = null;
TreeNode right = null;
public TreeNode(int val) {
this.val = val;
}
}
*/
public class Solution {
public void Mirror(TreeNode root) {
if(root == null)
return;
TreeNode i = root.left;//作为第三量用于交换左右节点
root.left = root.right;
root.right = i;
Mirror(root.left);//参考前序遍历代码
Mirror(root.right);
}
}