问题描述:
给你一棵二叉树的根节点 root ,翻转这棵二叉树,并返回其根节点。
示例1:
输入:root = [4,2,7,1,3,6,9]
输出:[4,7,2,9,6,3,1]
解题思路:递归
- 首先判断输入二叉树是否为空,如果为空直接返回null
- 借助第三方节点,交换以root为根的左右子树
- 然后递归调用这个函数,去它的内部继续交换
代码实现(js)
/**
* Definition for a binary tree node.
* function TreeNode(val, left, right) {
* this.val = (val===undefined ? 0 : val)
* this.left = (left===undefined ? null : left)
* this.right = (right===undefined ? null : right)
* }
*/
/**
* @param {TreeNode} root
* @return {TreeNode}
*/
var invertTree = function(root) {
// 1.如果root为空,直接返回
if(root === null){
return null
}
// 2.利用第三方来交换root的左右节点
const temp = root.left
root.left = root.right
root.right = temp
// 3.递归翻转子节点
invertTree(root.left)
invertTree(root.right)
return root
};