剑指offer面试题27-二叉树的镜像

剑指offer面试题27:二叉树的镜像

题目:输入一棵二叉树,使用函数进行镜像翻转

1
2
3
4
5
function TreeNode(x){
this.val = x
this.left = null
this.right = null
}

思路: 
这道题本质上还是二叉树的遍历问题,其实就是在遍历过程中看看当前遍历到的这个节点是不是叶子节点,如果不是,那么就交换这个节点的左右子树,否则不做任何操作。
根据这个思路,这道题用递归就可以很简单地解决,根据分析,递归终点的设置,就是传入的节点是一个叶子节点。

代码如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
function mirror(a){
if(a === null) return null
if(a.left === null && a.right === null){
return null
}
let flag = a.left
a.left = a.right
a.right = flag
if(a.left){
mirror(a.left)
}
if(a.right){
mirror(a.right)
}
}
  • Copyright: Copyright is owned by the author. For commercial reprints, please contact the author for authorization. For non-commercial reprints, please indicate the source.

扫一扫,分享到微信

微信分享二维码
  • Copyrights © 2020-2024 AuroraAksnesOs

请我喝杯咖啡吧~

支付宝
微信