剑指 offer 树算法题:镜像二叉树

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

分析:比如,源二叉树为:

            8

           /  \

          6   10

         / \  / \

        5  7 9 11

其镜像二叉树,其镜像二叉树,即左右子树进行对调,递归对调即可:先分别递归求得左右子树的镜像,然后将左子树镜像与右子树镜像分别挂着右左子树上,即对调,结果如下:

            8

           /  \

          10   6

         / \  / \

        11 9 7  5

求解:

class TreeNode<T> {
  val: T;
  left: TreeNode<T> | null;
  right: TreeNode<T> | null;
  constructor(val: T, left: TreeNode<T> | null = null, right: TreeNode<T> | null = null) {
    this.val = val;
    this.left = left;
    this.right = right;
  }
}

// 递归
function mirrorTree<T>(root: TreeNode<T> | null): TreeNode<T> | null {
  if (root === null) return null;
  // 先分别递归求得左右子树的镜像
  const left = mirrorTree(root.left);
  const right = mirrorTree(root.right);
  // 将左子树镜像与右子树镜像分别挂着右左子树上,即对调
  root.left = right;
  root.right = left;
  return root;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薛定谔的猫96

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值