二叉树的镜像

简介: 二叉树的镜像

前言


给定一颗二叉树,如何获取它的镜像?本文将跟大家分享这个问题的解决方案,欢迎各位感兴趣的开发者阅读本文。


思路分析


当我们把一张写有文字的纸放在镜子前面,你看到的内容正好与你写的内容是相反的。那么我们就可以依据照镜子的经验画出它的镜像了,如下所示:


  • 镜像前后的两棵树根节点相同
  • 镜像后的树与镜像前相比:它们的左、右子节点交换了位置


640.png

                    image-20220713220838785


通过观察后,我们就得出了一颗树的镜像过程:先序遍历这棵树的每个节点,如果遍历到的节点有子节点,就交换它的两个子节点。当交换完所有非叶节点的左、右子节点之后,就得到了树的镜像。


对树的遍历不了解的开发者,请移步我的另一篇文章:先序遍历


实现代码


想清楚思路后,我们就可以很顺利的写出代码了,如下所示:


export function MirrorImageOfTree(node: BinaryTreeNode | null): void {
  if (node == null) return;
  if (node.left == null && node.right == null) return;
  // 交换左右子节点
  const temp = node.left;
  node.left = node.right;
  node.right = temp;
  if (node.left) {
    MirrorImageOfTree(node.left);
  }
  if (node.right) {
    MirrorImageOfTree(node.right);
  }
}


完整代码请移步:MirrorImageOfTree.ts


我们将文章开头所讲的例子代入上述代码来测试下,如下所示:


const tree: BinaryTreeNode = {
  key: 8,
  left: {
    key: 5,
    left: { key: 3 },
    right: { key: 7 }
  },
  right: { key: 18, left: { key: 13 }, right: { key: 22 } }
};
MirrorImageOfTree(null);
console.log("镜像后的树", tree);



640.png

                              image-20220717114620029


完整代码请移步:mirrorImage-test.ts


写在最后


至此,文章就分享完毕了。


我是神奇的程序员,一位前端开发工程师。


如果你对我感兴趣,请移步我的个人网站,进一步了解。

  • 公众号无法外链,如果文中有链接,可点击下方阅读原文查看😊
相关文章
【剑指offer】-二叉树的镜像-18/67
【剑指offer】-二叉树的镜像-18/67
|
7月前
牛客网-二叉树的镜像
牛客网-二叉树的镜像
35 0
|
3月前
|
存储 监控 持续交付
Docker 知识树
【9月更文挑战第08天】
25 2
|
7月前
|
存储 Linux 应用服务中间件
安装docker 并搭建出一颗爱心树
Docker是Go语言编写的开源容器运行时软件,遵循Apache2.0协议,提供应用封装和跨平台运行能力,灵感来自集装箱。主要组件包括镜像(静态模板)、容器(运行时实例)和仓库(镜像存储库)。最大公开仓库是Docker Hub,国内有阿里、网易等公开仓库。在Redhat 9环境下,安装Docker涉及配置阿里云仓库、安装yum-utils、添加仓库、安装Docker软件包、设置镜像加速、拉取Nginx镜像并创建运行容器,实现端口映射和持久化存储。
87 1
安装docker 并搭建出一颗爱心树
|
C++
构建二叉树
构建二叉树
59 0
构建二叉树
剑指offer 26. 二叉树的镜像
剑指offer 26. 二叉树的镜像
36 0
剑指offer_二叉树---二叉树的镜像
剑指offer_二叉树---二叉树的镜像
46 0
二叉树的镜像(简单难度)
二叉树的镜像(简单难度)
63 0
二叉树的镜像(简单难度)
|
存储 算法 C++
|
存储 算法
每日一练(15):二叉树的镜像
请完成一个函数,输入一个二叉树,该函数输出它的镜像。
160 0