给定一颗二叉树,如何获取它的镜像?本文将跟大家分享这个问题的解决方案,欢迎各位感兴趣的开发者阅读本文。 思路分析 当我们把一张写有文字的纸放在镜子前面,你看到的内容
给定一颗二叉树,如何获取它的镜像?本文将跟大家分享这个问题的解决方案,欢迎各位感兴趣的开发者阅读本文。 思路分析当我们把一张写有文字的纸放在镜子前面,你看到的内容正好与你写的内容是相反的。那么我们就可以依据照镜子的经验画出它的镜像了,如下所示:
通过观察后,我们就得出了一颗树的镜像过程:先序遍历这棵树的每个节点,如果遍历到的节点有子节点,就交换它的两个子节点。当交换完所有非叶节点的左、右子节点之后,就得到了树的镜像。 对树的遍历不了解的开发者,请移步我的另一篇文章:先序遍历 实现代码想清楚思路后,我们就可以很顺利的写出代码了,如下所示:
完整代码请移步:MirrorImageOfTree.ts 我们将文章开头所讲的例子代入上述代码来测试下,如下所示:
完整代码请移步:mirrorImage-test.ts https://github.com/likaia/algorithm-practice/blob/078a16fd56515befbe11bfb7989c1c08ea0e017d/src/test-case/mirrorImage-test.ts#L4 |
2021-06-04
2019-01-10
2019-02-17
2021-09-12
2021-09-30