剑指:二叉树的镜像

题目描述

输入一个二叉树,将它变换为它的镜像。

输入树:
      8
     / 
    6  10
   /  / 
  5  7 9 11

 [8,6,10,5,7,9,11,null,null,null,null,null,null,null,null] 
输出树:
      8
     / 
    10  6
   /  / 
  11 9 7  5

 [8,10,6,11,9,7,5,null,null,null,null,null,null,null,null]

解法

将根结点的左右孩子互换,之后递归左右孩子。

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public void mirror(TreeNode root) {
        if (root == null || (root.left == null && root.right == null)) {
            return;
        }
        TreeNode t = root.left;
        root.left = root.right;
        root.right = t;
        mirror(root.left);
        mirror(root.right);
    }
}
原文地址:https://www.cnblogs.com/lisen10/p/11183577.html