2021.11.29算法笔记
剑指 Offer 27. 二叉树的镜像
请完成一个函数,输入一个二叉树,该函数输出它的镜像。
例如输入:
4
/
2 7
/ \ /
1 3 6 9
镜像输出:
4
/
7 2
/ \ /
9 6 3 1
示例 1:
输入:root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]
自己的思路:
使用递归思路来解决即可
方法一:实现递归
解题代码:
/**
* Definition for a binary tree node.
* function TreeNode(val) {
* this.val = val;
* this.left = this.right = null;
* }
*/
/**
* @param {TreeNode} root
* @return {TreeNode}
*/
var mirrorTree = function (root) {
// 应该使用递归的思路来解决,或者遍历的思路。
if (root!=null) {
//这种数组的方式来置换的确是没想啊
[root.left, root.right] = [root.right, root.left];
// TreeNode toor = root;
// root.left = toor.right;
// right.right = toor.left;
mirrorTree(root.left);
mirrorTree(root.right);
}
//对root的子节点操作,返回root就行了。
return root
};
方法二:使用辅助栈(或者队列)
- 利用栈(或队列)遍历树的所有节点 nodenode ,并交换每个 nodenode 的左 / 右子节点。