剑指Offer对答如流系列 - 二叉树的镜像

Posted jefferychenxiao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指Offer对答如流系列 - 二叉树的镜像相关的知识,希望对你有一定的参考价值。

面试题27:二叉树的镜像

题目描述

请完成一个函数,输入一个二叉树,该函数输出它的镜像。

树的结构如下:

  public class TreeNode {
        int val = 0;
        TreeNode left = null;
        TreeNode right = null;
        public TreeNode(int val) {
            this.val = val;
        }
    }

B是A的镜像
技术图片

问题分析

镜像 这个名词看起来很高大上。

其实就是每个结点交换左右子结点。

我们通过前序遍历,依次处理即可。

问题解答

  public void Mirror(TreeNode root) {
        if(root==null) {
            return;
        }
        //左右子结点交换 -- 核心代码
        TreeNode tempNode = root.left;
        root.left=root.right;
        root.right=tempNode;

        Mirror(root.left);
        Mirror(root.right);
    }

以上是关于剑指Offer对答如流系列 - 二叉树的镜像的主要内容,如果未能解决你的问题,请参考以下文章

剑指Offer对答如流系列 - 二叉树的深度

剑指Offer对答如流系列 - 树的子结构

剑指Offer对答如流系列 - 从上往下打印二叉树

剑指Offer对答如流系列 - 序列化二叉树

剑指Offer对答如流系列 - 二叉树中和为某一值的路径

二叉树的镜像-剑指offer系列