剑指Offer 27.二叉树的镜像

这篇博客介绍了如何使用栈和队列以及递归两种方式来实现二叉树的镜像翻转。栈或队列实现中,通过不断入队和出队节点并交换左右子树实现;递归实现则通过临时保存左子节点,然后交换左右子节点完成。这两种方法都有效地反转了二叉树的结构。
摘要由CSDN通过智能技术生成

剑指Offer 27.二叉树的镜像

在这里插入图片描述
利用栈或者队列实现
将根节点入队,再出队,将该结点的左右子树入队,交换该结点的左右子树,再将队列中的结点出队,交换该结点的左右子树,重复此步骤,直到队列为空。返回根节点。

class Solution {
    public TreeNode mirrorTree(TreeNode root) {
        if(root == null) return null;
         Queue<TreeNode> tree = new LinkedList<>();
        tree.add(root);
        while(!tree.isEmpty()) {
            TreeNode node = tree.remove();
        	if(node.left != null) tree.add(node.left);
        	if(node.right != null) tree.add(node.right);
        	TreeNode temp = node.left;
        	node.left = node.right;
        	node.right = temp;
        }
        return root;
    }
}

在这里插入图片描述

利用递归实现:
递归解析:
终止条件: 当节点 rootroot 为空时(即越过叶节点),则返回 null ;
递推工作:
初始化节点 tmp ,用于暂存 root的左子节点;
开启递归 右子节点 mirrorTree(root.right),并将返回值作为 rootroot 的 左子节点
开启递归 左子节点 mirrorTree(tmp) ,并将返回值作为 rootroot 的 右子节点
返回值: 返回当前节点 rootroot ;
Q: 为何需要暂存 rootroot 的左子节点?
A: 在递归右子节点 “root.left = mirrorTree(root.right);root.left=mirrorTree(root.right);” 执行完毕后, root.leftroot.left 的值已经发生改变,此时递归左子节点 mirrorTree(root.left)mirrorTree(root.left) 则会出问题。

class Solution {
    public TreeNode mirrorTree(TreeNode root) {
        if(root == null) return null;
        TreeNode temp = root.left;
        root.left = mirrorTree(root.right);
        root.right = mirrorTree(temp);
        return root;
    }
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值